×

EmberJS 教程

EmberJS 概述EmberJS 环境配置EmberJS 应用EmberJS 对象模型EmberJS 模板EmberJS 路由器EmberJS 组件EmberJS 模型EmberJS 视图EmberJS 控制器EmberJS 测试EmberJS 指定查询参数

Ember 对象模型

Ember 类的定义 初始化 继承Ember 类的扩展Ember 计算属性Ember 观察者Ember 数据绑定Ember 枚举Ember 第一章对象模型小结

Ember handlebars模板

Ember handlebars基础Ember handlebars条件表达式Ember handlebars遍历标签Ember handlebars显示对象键Ember handlebars属性绑定Ember {{link-to}} 助手Ember 路由 模板执行渲染顺序Ember {{action}} 助手Ember 表单元素Ember 调试助手Ember 工具类的助手Ember 第二章模板小结

Ember 路由

Ember 路由定义Ember 指定与路由关联的模型Ember 模板渲染Ember 路由重定向Ember 路由终止挑战和激活Ember loading error子路由Ember 查询参数Ember 异步路由

Ember 组件

Ember 组件定义Ember 属性传递Ember 包裹内容自定义包裹组件的HTML标签Ember 处理事件Ember action触发变化

Ember 控制器

Ember 控制器Ember 管理控制器的依赖关系

Ember 模型

Ember model简介Ember 定义模型Ember 记录查询Ember 新建、更新、删除记录Ember 设置记录到StoreEmber model的关联关系处理Ember 元数据Ember 自定义适配器Ember 自定义序列号器

Ember 测试

Ember 测试简介Ember 验收测试Ember 单元测试

EmberJS 测试用户交互


EmberJS 测试EmberJS 测试


测试用户交互

用户可以使用助手与页面交互,并检查DOM中的更改。当未经授权的用户尝试访问特定的URL时,您可以将其转换为登录页面。

例子

<!DOCTYPE html>
   <html>
      <head>
         <title>Emberjs Testing Interaction</title>
         <!-- CDN's-->
         <script src="https://cdnjs.cloudflare.com/ajax/libs/handlebars.js/3.0.1/handlebars.min.js"></script>
         <script src="https://code.jquery.com/jquery-2.1.3.min.js"></script>
         <script src="https://builds.emberjs.com/tags/v1.10.0-beta.3/ember-template-compiler.js"></script>
         <script src="https://cdnjs.cloudflare.com/ajax/libs/ember.js/1.10.0/ember.prod.js"></script>
         <!-- CDN's for testing Ember.js programs --<
         <script src="https://code.jquery.com/qunit/qunit-1.18.0.js"></script>
         <script src="https://rawgit.com/rwjblue/ember-qunit-builds/master/ember-qunit.js"></script>
		 <script src="https://builds.emberjs.com/release/ember.debug.js"></script>
         <script src="https://builds.emberjs.com/beta/ember-data.js"></script>
     </head>
     <body>
     <div id="qunit"></div>
     <div id="ember-testing"></div>

     <!-- These are used to link different url's -->
     <script type="text/x-handlebars">
        <ul>
           <li>{{#link-to "index"}}Login 1{{/link-to}}</li>
           <li>{{#link-to "Login2"}}Login 2{{/link-to}}</li>
        </ul>
        {{/outlet}}
     </script>

     <script type="text/x-handlebars" data-template-name="index">
        <p>This is login 1</p>
     </script>

     <!-- Display this line if not authenticated -->
     <script type="text/x-handlebars" data-template-name="login">
        <p>This is my Login</p>
     </script>

     <script type="text/x-handlebars" data-template-name="Login2">
        <p>This is login 2</p>
     </script>

     <script type="text/javascript">
        //Creates an instance of Ember.Application and assign it to a global variable
        App = Ember.Application.create();

        //The map method of application's router can be invoked to define URL mappings
        App.Router.map(function() {
           this.route('login');
           this.route('Login2');
        });

        // 'Login2Route' should render by defining a route with the same name as the template
        App.Login2Route = Ember.Route.extend({
           beforeModel: function() {
              var myval = this.modelFor('application');
                 //If we pass an empty object, then it create a link to a route using 'transitionTo' method
                 if (Ember.isEmpty(myval)) {
                    this.transitionTo('login');
                 }
           }
        });

        //These methods are used to prepare the application for testing
        App.setupForTesting();
        App.injectTestHelpers();
        App.rootElement = '#ember-testing';   //Ember.js applications's root element

        module('Emberjs', {
           setup: function() {
              App.reset();   //After each test, reset the state of the application
           }
        });

        //Here, it tests the workflow of an application
        test('redirect to login if not authenticated', function() {
           visit('/');
           click('.Login2');

           //'andThen' helper wait for the preceding asynchronous test helpers to complete
           andThen(function() {
              equal(currentRouteName(), 'login');
           });
        });
     </script>
     </body>
</html>

输出

让我们执行以下步骤,看看上面的代码如何工作:

  • 将上面的代码保存在testing_userinteraction.html文件中

  • 在浏览器中打开此HTML文件。


EmberJS 测试EmberJS 测试


分类导航

关注微信下载离线手册

bootwiki移动版 bootwiki
(群号:472910771)