2017-10-16 12 views
0

私は、私は機能onMultiSelectPressのためのユニットテストを書くことqunit + sinon.jsに新たたいので、私はモックする必要があります:ui5でビューモデルをスタブする方法は?

this.myController._oList

this.myController.getResourceBundle()

this.myController.getModel("masterView")

右?

私は、getModel("masterView")のスタブを手に入れませんでした。

onInit : function() { 
    var oList = this.byId("list"), 
     oViewModel = this._createViewModel(); 
    this._oList = oList; 
    this.setModel(oViewModel, "masterView");  
}, 

_createViewModel : function() { 
    return new JSONModel({ 
     isFilterBarVisible: false, 
     filterBarLabel: "", 
     delay: 0, 
     title: this.getResourceBundle().getText("masterTitleCount", [0]), 
     noDataText: this.getResourceBundle().getText("masterListNoDataText"), 
     sortBy: "Name", 
     groupBy: "None", 
     listMode: "SingleSelectMaster", 
     showDeleteButton: false 
    }); 
}, 

getModel : function (sName) { 
    return this.getView().getModel(sName); 
}, 

onMultiSelectPress : function() { 
    var oMasterViewModel = this.getModel("masterView"); 

    switch(this._oList.getMode()) { 
     case "MultiSelect": 
      oMasterViewModel.setProperty("/listMode", "SingleSelectMaster"); 
      oMasterViewModel.setProperty("/showDeleteButton", false); 
      break; 
     case "SingleSelectMaster": 
      oMasterViewModel.setProperty("/listMode", "MultiSelect"); 
      oMasterViewModel.setProperty("/showDeleteButton", true); 
      break; 
    } 
}, 

答えて

1

beforeEachでoViewStubを追加し、テストのために使用して、空のJSONモデルを設定します。

QUnit.module("MasterController", { 
     beforeEach: function() { 
      this.oMasterController = new MasterController(); 
      this.models = {}; 
      var oViewStub = { 
       setModel: function(model, name) { 
        this.models[name] = model; 
       }.bind(this), 
       getModel: function(name) { 
        return this.models[name]; 
       }.bind(this) 
      }; 
      sinon.stub(Controller.prototype, "getView").returns(oViewStub); 
     }, 

     afterEach: function() { 
      this.oMasterController.destroy(); 
      jQuery.each(this.models, function(i, model) { 
       model.destroy(); 
      }); 
      Controller.prototype.getView.restore(); 
     } 
    }); 

    QUnit.test("test onMultiSelectPress() ", function(assert) { 
     var oMasterController = this.oMasterController; 
     var oModel = new JSONModel(); 
     oMasterController.setModel(oModel, "masterView"); 
     var oMasterViewModel = oMasterController.getModel("masterView"); 

     oMasterController._oList = new sap.m.List(); 
     sinon.stub(oMasterController._oList, "getMode").returns("MultiSelect"); 
     oMasterController.onMultiSelectPress(); 
     assert.strictEqual(oMasterViewModel.getProperty("/listMode"), "SingleSelectMaster", "Did change list mode to SingleSelectMaster"); 
     assert.strictEqual(oMasterViewModel.getProperty("/showDeleteButton"), false, "Did hide the delete button"); 

     oMasterController._oList.getMode.restore(); 
     sinon.stub(oMasterController._oList, "getMode").returns("SingleSelectMaster"); 
     oMasterController.onMultiSelectPress(); 
     assert.strictEqual(oMasterViewModel.getProperty("/listMode"), "MultiSelect", "Did change list mode to MultiSelect"); 
     assert.strictEqual(oMasterViewModel.getProperty("/showDeleteButton"), true, "Did show the delete button"); 

     oMasterController._oList.destroy(); 
    }); 
+0

unit test onInitメソッドはどのようにすることができますか?メソッドの存在をテストできますが、内部でJSONをテストすることはできません。 'のOnInit:関数のOnInit(){ フォーマットのテキストコントロールにバインドされた// HTML文字列 VAR oModel =新しいJSONModel({ タイトル: 'こんにちは'、 メッセージ: '

あなた

' + 受け入れる:「私を「受け入れる」、 拒否: '私は拒否する' }); this.getView()。setModel(oModel); }、 ' – user557657

+0

'assert.ok(this.getView()。getModel(oModel))'? @ user557657 – Tina

+0

ユニットテストで 'this'リファレンスを取得できません。 – user557657

関連する問題