Đang chuẩn bị nút TẢI XUỐNG, xin hãy chờ
Tải xuống
Tham khảo tài liệu 'phát triển javascript - part 43', công nghệ thông tin, kỹ thuật lập trình phục vụ nhu cầu học tập, nghiên cứu và làm việc hiệu quả | 15.2 The User Form 393 The next test shown in Listing 15.5 expects setView to be a function. Listing 15.5 Expecting setview to be a function test should have setView method function assertFunction userController.setView Listing 15.6 adds an empty method to pass the test. Listing 15.6 Adding an empty setview method function function setView element tddjs.namespace chat .userFormController setview setview 15.2.1.2 Adding a Class The first actual behavior we ll test for is that the js-chat class name is added to the DOM element as seen in Listing 15.7. Note that the test requires the Object.create implementation from Chapter 7 Objects and Prototypal Inheritance in lib object.js to run smoothly across browsers. Listing 15.7 Expecting the view to have its class name set TestCase UserFormControllerSetViewTest test should add js-chat class function var controller Object.create userController var element controller.setView element assertClassName js-chat element The first thing that sticks out about this test is that it contains no DOM elements. It does however use the assertClassName assertion which checks if an element has the given class name. This assertion is generic and only checks that the object defines a string property className and that one of its space separated values matches the provided string. Download from www.eBookTM.com 394 TDD and DOM Manipulation The Chat Client The element object is a simple stub object. At this point there s no need to use a real DOM element because all we want to check is that some property was assigned. The test fails and Listing 15.8 assigns the class name to pass it. Listing 15.8 Adding the class function setView element element.className js-chat At this point you might worry about a few things. Should we really be overriding the class name like that Should the class name not be configurable Remember You ain t gonna need it At this point we have no use case demonstrating the need to use an element that already has class names or