Ember.js: Uncaught TypeError:undefinedのプロパティ 'hasRoute'を読み取ることができません

作成日 2015年08月11日  ·  4コメント  ·  ソース: emberjs/ember.js

単体テストを作成しようとしている認証サービスがあります。

Authサービスに以前の遷移が保存されていない場合、特定のルートにリダイレクトされます。

アプリは期待どおりに動作しますが、このサービスのテストでは次のエラーが発生します。

Uncaught TypeError: Cannot read property 'hasRoute' of undefined

これをデバッグ/解決する方法がわかりません。 どうしたの?

これが私の認証サービスです:

import Ember from 'ember';
import config from '../config/environment';

export default Ember.Service.extend({
    routing: Ember.inject.service('-routing'),
    loginCapable: true,
    localStorageKey: config.localStorageKeys.user,

    checkAuth(priorTransition){
        this.set('priorTransition', priorTransition);
        return this.get('isLoggedIn');
    },

    isLoggedIn: Ember.computed('user', function(){
        return !!this.get('user');
    }),

    init(){
        this.set('user', JSON.parse(window.localStorage.getItem( this.get("localStorageKey") )) );
    },

    login(adID){
        return Ember.$.ajax(
            config.apiHost + config.apiVersion + "/getLdapInfo",{
                type: 'GET',
                data: "adID="+adID
            }).then(json => {
                this.set('user', json);

                window.localStorage.setItem( this.get("localStorageKey") , JSON.stringify(json));

                var priorTransition = this.get('priorTransition');
                if( priorTransition )
                {
                    priorTransition.retry();
                    this.set('priorTransition', null);
                }else{
                    this.get('routing').transitionTo('index');

                }
            }, xhr => {
                return xhr.responseJSON ? xhr.responseJSON.message : "Login failed";
            });
    }
});

そして私のルーター:

import Ember from 'ember';
import config from './config/environment';

var Router = Ember.Router.extend({
  location: config.locationType
});

Router.map(function() {
  this.route('authenticated', { path: '/' }, function(){
    this.route('index', { resetNamespace: true });
  });
  this.route('login');
});

export default Router;

そのサービスのテストは次のとおりです。

import { moduleFor, test } from 'ember-qunit';
import Ember from 'ember';
import startApp from 'recruiter-admin/tests/helpers/start-app';
import Pretender from 'pretender';

var server,
    application;

var user = [{
            "adID":"uniqueID",
            "first_name":"First Name",
            "last_name":"Last Name",
            "employee_type":"Regular",
            "employee_id":"12345",
            "manager":"CN=managerID,OU=Employees,OU=company Users,DC=company,DC=com",
            "success":true
            }];

function jsonResponse(json, status = 200) {
    return [status, {"Content-Type": "application/json"}, JSON.stringify(json)];
}

moduleFor('service:auth', 'Unit | Service | auth', {
    unit:true,
    needs:['router:main'],
    beforeEach(){
        application = startApp();

        server = new Pretender(function(){
            this.get('/getLdapInfo', function(req){
                return jsonResponse(user.findBy('adID',req.queryParams.adID));
            });
        });
    },

    afterEach(){
        Ember.run(application, 'destroy');
        if( server ){
            server.shutdown();
        }
    }
});

// Replace this with your real tests.
test('it exists', function(assert) {
    var service = this.subject();
    assert.ok(service);
});

test('isLoggedIn Testing', function(assert){
    var service = this.subject();
    assert.ok(service.get('isLoggedIn') === false, 'Not logged in');

    Ember.run(()=>{
        service.set('user', true);
    });

    assert.ok(service.get('isLoggedIn') === true, 'IS logged in');
});

test('can login', function(assert){
    assert.expect(0);

    var service = this.subject();
    Ember.run(()=>{
        service.login('uniqueID');
    });

    andThen(()=>{
        assert.ok(service.get('user'));
    });

});

Ember2.0.0-beta.5を使用する

最も参考になるコメント

プライベート-routingサービスを使用しており、 routerインスタンスが初期化およびセットアップされている必要があります。 このテストではそれが行われないため、モックを作成するか、ルーターをセットアップする必要があります。

このエラーを防ぐためにhttps://github.com/emberjs/ember.js/blob/master/packages/ember-routing/lib/services/routing.js#L37を少し調整することに反対していません(最終的にはget(this, 'router')がfalseの場合はfalse)PRを送信したいが、サポートされていない方法でプライベートAPIを使用する場合はバグではありません。

全てのコメント4件

プライベート-routingサービスを使用しており、 routerインスタンスが初期化およびセットアップされている必要があります。 このテストではそれが行われないため、モックを作成するか、ルーターをセットアップする必要があります。

このエラーを防ぐためにhttps://github.com/emberjs/ember.js/blob/master/packages/ember-routing/lib/services/routing.js#L37を少し調整することに反対していません(最終的にはget(this, 'router')がfalseの場合はfalse)PRを送信したいが、サポートされていない方法でプライベートAPIを使用する場合はバグではありません。

この号を締めくくりますが、PRを喜んで確認したいと思います。

ゲームに遅れましたが、私はそのような問題を解決するために私がした方法を示したいだけです。

メソッドをオーバーライドするだけです。

const service = this.subject({
    routing: {
      transitionTo() {
        return true;
      }
    }
})

さまざまなルート自体をテストするためのテストを作成したため、これを行っています。また、残り火チームがember/service/routing.jsをテストすることを信頼しています。

this.owner.unregister('service:router');
this.owner.register('service:router', mocks.routerService());

テストケースに失敗せずにスタブする1つの方法

このページは役に立ちましたか?
0 / 5 - 0 評価