2016-07-12 130 views
1

我寫了一個簡單的模擬測試服務在打字稿文件的方法(改變())(EditUser.ts)角2 - jasmine-測試方法打字稿

我收到以下錯誤,當嘗試執行在edituser.spec.ts

TypeError: Cannot read property 'changed' of undefined 
    at Object.eval (http://localhost:3000/app/Tracker/EditUserAdmin/EditUser.spec.js:94:12) 
    at attemptSync (http://localhost:3000/node_modules/jasmine-core/lib/jasmine-core/jasmine.js:1886:24) 
    at QueueRunner.run (http://localhost:3000/node_modules/jasmine-core/lib/jasmine-core/jasmine.js:1874:9) 
    at http://localhost:3000/node_modules/jasmine-core/lib/jasmine-core/jasmine.js:1898:16 
    at http://localhost:3000/node_modules/jasmine-core/lib/jasmine-core/jasmine.js:1842:9 
    at http://localhost:3000/node_modules/angular2/bundles/testing.dev.js:2116:15 
    at ZoneDelegate.invoke (http://localhost:3000/node_modules/angular2/bundles/angular2-polyfills.js:390:29) 
    at Zone.run (http://localhost:3000/node_modules/angular2/bundles/angular2-polyfills.js:283:44) 
    at http://localhost:3000/node_modules/angular2/bundles/angular2-polyfills.js:635:58 
    at ZoneDelegate.invokeTask (http://localhost:3000/node_modules/angular2/bundles/angular2-polyfills.js:423:38) 

EditUser.spec.ts

import {EditUserAdmin} from "./EditUser.component"; 
import { 
    it, 
    inject, 
    injectAsync, 
    describe, 
    beforeEachProviders, 
    beforeEach, 
    TestComponentBuilder, 
    setBaseTestProviders, 
    ComponentFixture, 
    expect 
} from 'angular2/testing'; 
import {provide} from 'angular2/core'; 
import { Component, OnInit, 
    ROUTER_DIRECTIVES, RouteParams, Router, 
    Http, HTTP_PROVIDERS, Headers, 
    CRUDService, 
    APIService } from '../index'; 
import { 
    TEST_BROWSER_PLATFORM_PROVIDERS, 
    TEST_BROWSER_APPLICATION_PROVIDERS 
} from 'angular2/platform/testing/browser'; 
class MockApiService { 
    getAPI() { 
     return { 
      TeamDrpList: "TrackerUser/GetUserCreateTeamMember", 
      UserDrpList: "TrackerGroup/GetAllList" 
     } 
    } 
} 
class MockCRUD { 
} 
class MockRouter { 
} 
setBaseTestProviders(TEST_BROWSER_PLATFORM_PROVIDERS, TEST_BROWSER_APPLICATION_PROVIDERS); 
describe('EditUserAdmin',() => { 
    var app : EditUserAdmin; 
    beforeEach(injectAsync([TestComponentBuilder], (tcb: TestComponentBuilder) => { 
     return tcb 
      .overrideProviders(EditUserAdmin, [ 
       provide(CRUDService, { useClass: CRUDService }), 
       provide(APIService, { useClass: MockApiService }), 
       provide(RouteParams, { useValue: new RouteParams({ UserId: '1' }) }), 
       provide(Router, { useClass: MockRouter }) 
      ]) 
      .createAsync(EditUserAdmin) 
      .then((componentFixture: any) => { 
       this.component = componentFixture; 
      }); 
    }));  
    it('Change Event Method',() => {    
      app.changed("india"); 
       expect(app.selectControl).toEqual("india");   
    }); 
}); 

EditUser.ts

import { Component, OnInit, 
    ROUTER_DIRECTIVES, RouteParams, Router, 
    Http, HTTP_PROVIDERS, Headers, 
    CRUDService, 
    APIService } from '../index'; 
import "rxjs/Rx"; 

@Component({ 
    templateUrl: 'app/Tracker/EditUserAdmin/EditUser.component.html', 
    directives: [ROUTER_DIRECTIVES], 
    providers: [HTTP_PROVIDERS, CRUDService, APIService] 
}) 
export class EditUserAdmin implements OnInit { 

    selectedCity: string; 
    items: any[]; //select dropdown array 
    teams: any[]; 
    GroupValue: any[] = []; 
    TeamValue: any[] = []; 
    optionAvailable: boolean = false; 
    ProfileDetails: any; 
    assignedGroup: any[]; 
    assignedTeam: any[]; 
    Get_APIService: any; 
    GetUserurl: string; 
    GroupUrl: string; 
    GetUserID: string; 
    selectControl: string; //Group Assignment Change event 
    selectTeam: string; 
    insertGroupId: any; 
    QueryString: string; 
    isBrokerHidden: boolean; 
    ErrorMsg: string; 
    SuccessMsg: string; 

    constructor(private CRUDService: CRUDService, private APIService: APIService, params: RouteParams, private router: Router) { 
     //To invoke Http service 
     this.Get_APIService = this.APIService.getAPI(); 
     this.GetUserID = params.get("UserId"); 
     this.ProfileDetails = { 
      LastName: "", 
      FirstName: "", 
      LoginName: "", 
      Email: "", 
      IsBrokerUser: false 
     } 
     this.QueryString = params.get("UserId"); 
     this.isBrokerHidden = true; 
    } 
    ngOnInit() { 
     this.GroupUrl = this.Get_APIService.GetTrackerGroup + "?NewtrackeruserID=" + this.GetUserID; 
     this.CRUDService.getServerData(this.Get_APIService.TeamDrpList + "?NewtrackeruserID=" + this.GetUserID, "") 
      .subscribe(
      data => { 
       this.teams = data.TeamMembersAvailable; 
       // this.items = data.GroupAvailable; 
       this.assignedTeam = data.TeamMembersAssigned.map(function (a) { 
        return { GroupName: a.DisplayName, AssignedId: a.UserID }; 
       }); 
       this.TeamValue.push.apply(this.TeamValue, this.assignedTeam); 
      }, 
      error => this.CRUDService.logError(error) 
      ); 
     this.CRUDService.getServerData(this.GroupUrl, "") 
      .subscribe(
      data => { 
       this.items = data.GroupAvailable; 
       this.assignedGroup = data.GroupAssigned.map(function (a) { 
        return { GroupName: a.Name, AssignedId: a.GroupID }; 
       }); 
       this.GroupValue.push.apply(this.GroupValue, this.assignedGroup); 
      }, 
      error => this.CRUDService.logError(error) 
      ); 
     if (this.QueryString != "0") { 
      this.GetUserurl = this.Get_APIService.GetUser + this.GetUserID; 
      this.CRUDService.getServerData(this.GetUserurl, "") 
       .subscribe(
       data => { 
        this.ProfileDetails = data; 
       }, 
       error => this.CRUDService.logError(error) 
       ); 
      setTimeout(() => { 
       this.CRUDService.getServerData(this.Get_APIService.BrokoerUrl, "") 
        .subscribe(
        data => { 
         if (this.GroupValue.length > 0) { 
          var Groupary = this.GroupValue.map(function (a) { return a.AssignedId; }); 
          // this.ProfileDetails = data; 
          this.isBrokerHidden = !(Groupary.indexOf(data.GroupID) > -1); 
         } 
        }, 
        error => this.CRUDService.logError(error) 
        ); 
      }, 100); 
     } 
    } 
    //Select dropdown Change Event-IE 11 support 
    changed(selectedValue: string) { 
     this.selectControl = selectedValue; 
    } 
    ChangeTeam(value: string) { 
     this.selectTeam = value; 
    } 
    //Event to add the Group 
    addGroup(value) { 
     var a, b; 
     var selectedname: string; 
     var selectedID: Number; 
     let ind = this.items.map(function (obj, index) { 
      if (obj.GroupID == value) { 
       a = index; 
       selectedname = obj.Name; 
       selectedID = obj.GroupID; 
       return a; 
      } 
     }); 
     if (a == "undefiened" || a == null) { 
      alert("Select Group Assignment"); 
      return false; 
     } else { 
      this.GroupValue.push({ GroupName: selectedname, AssignedId: selectedID }); 
     } 
     b = this.items.splice(a, 1); 
     this.items.sort(function (x, y) { 
      return (x.GroupID > y.GroupID) ? 1 : ((y.GroupID > x.GroupID) ? -1 : 0); 
     }); 
    } 
    addTeam(value) { 
     var a, b; 
     var selectedname: string; 
     var selectedID: Number; 
     let ind = this.teams.map(function (obj, index) { 
      if (obj.UserID == value) { 
       a = index; 
       selectedname = obj.DisplayName; 
       selectedID = obj.UserID; 
       return a; 
      } 
     }); 
     if (value == "undefiened" || value == null) { 
      alert("Select Team Member"); 
      return false; 
     } 
     else { 
      var headers = new Headers(); 
      headers.append('Content-Type', 'application/json'); 
      this.CRUDService.postServerData(this.Get_APIService.AddTeamMember + "?Trackeruserid=" + this.GetUserID + "&newMemberID=" + value, "", headers) 
       .subscribe(
       data => { 
        if (data == true) { 
         b = this.teams.splice(a, 1); 
         this.TeamValue.push({ GroupName: selectedname, AssignedId: selectedID }); 
        } 
        else { 

        } 
       }, 
       error => this.CRUDService.logError(error) 
       ); 
      this.teams.sort(function (x, y) { 
       return (x.UserID > y.UserID) ? 1 : ((y.UserID > x.UserID) ? -1 : 0); 
      }); 
     } 
    } 
    //Event to unassign the Group 
    unassignGroup(a: any) { 
     var selectobject = <HTMLSelectElement>document.getElementById("group-select"); 
     for (var i = 0; i < selectobject.length; i++) { 
      if ((<HTMLOptionElement>selectobject.options[i]).value == a.GroupName) { 
       this.optionAvailable = true; 
      } 
     } 
     if (this.optionAvailable == false) { 
      this.items.push({ 
       Name: a.GroupName, 
       GroupID: a.AssignedId 
      }); 
      var index = this.GroupValue.indexOf(a); 
      if (index > -1) { 
       this.GroupValue.splice(index, 1); 
       this.items.sort(function (a, b) { 
        return (a.GroupID > b.GroupID) ? 1 : ((b.GroupID > a.GroupID) ? -1 : 0); 
       }); 
      } 
     } 
    } 
    unassignTeam(a: any) { 
     var selectobject = <HTMLSelectElement>document.getElementById("Team-select"); 
     for (var i = 0; i < selectobject.length; i++) { 
      if ((<HTMLOptionElement>selectobject.options[i]).value == a.GroupName) { 
       this.optionAvailable = true; 
      } 
     } 
     if (this.optionAvailable == false) { 
      var headers = new Headers(); 
      headers.append('Content-Type', 'application/json'); 
      this.CRUDService.postServerData(this.Get_APIService.RemoveTeamMember + "?Trackeruserid=" + this.GetUserID + "&teamMemberID=" + a.AssignedId, "", headers) 
       .subscribe(
       data => { 
        if (data == true) { 
         // b = this.teams.splice(a, 1); 
         this.teams.push({ 
          DisplayName: a.GroupName, 
          UserID: a.AssignedId 
         }); 
        } 
        else { 
         // do nothing 
        } 
        var index = this.TeamValue.indexOf(a); 
        if (index > -1) { 
         this.TeamValue.splice(index, 1); 
         this.teams.sort(function (a, b) { 
          return (a.UserID > b.UserID) ? 1 : ((b.UserID > a.UserID) ? -1 : 0); 
         }); 
        } 
       }, 
       error => this.CRUDService.logError(error) 
       ); 


     } 
    } 
    EditUser() { 

     var headers = new Headers(); 
     if (this.QueryString != "0") { 
      this.insertGroupId = this.GroupValue.map(function (a) { return a.AssignedId; }); 
      var creds: string = JSON.stringify({ LastName: this.ProfileDetails.LastName, FirstName: this.ProfileDetails.FirstName, LoginName: this.ProfileDetails.LoginName, Email: this.ProfileDetails.Email, IsBrokerUser: this.ProfileDetails.IsBrokerUser, GroupID: this.insertGroupId, UserID: this.GetUserID }); 

      headers.append('Content-Type', 'application/json'); 
      this.CRUDService.postServerData(this.Get_APIService.SaveUser, creds, headers) 
       .subscribe(
       data => { 
        if (data == true) { 
         ///alert("User Saved"); 
         document.getElementById("ErrorStatus").style.display = "none"; 
         document.getElementById("SucessStatus").style.display = ""; 
         //document.getElementById("SucessStatus").innerHTML = ""; 
         this.SuccessMsg = "Tracker User information was saved successfully."; 
         scrollTo(0, 0); 

        } 
        else { 
         // do nothing 
        } 
       }, 
       error => { 
        if (error.status == 500) { 
         var errorMsg = JSON.parse(error._body); 
         // alert(); 
         document.getElementById("SucessStatus").style.display = "none"; 
         document.getElementById("ErrorStatus").style.display = ""; 
         //document.getElementById("ErrorStatus").innerHTML = "Tracker User information was saved successfully."; 
         this.ErrorMsg = errorMsg.ExceptionMessage; 
         scrollTo(0, 0); 
        } 
        this.CRUDService.logError(error);; 
       } 
       ); 
     } 

     else { 

      this.insertGroupId = this.GroupValue.map(function (a) { return a.AssignedId; }); 
      var creds: string = JSON.stringify({ LastName: this.ProfileDetails.LastName, FirstName: this.ProfileDetails.FirstName, LoginName: this.ProfileDetails.LoginName, Email: this.ProfileDetails.Email, IsBrokerUser: this.ProfileDetails.IsBrokerUser, GroupID: this.insertGroupId }); 
      headers.append('Content-Type', 'application/json'); 
      this.CRUDService.postServerData(this.Get_APIService.SaveUser, creds, headers) 
       .subscribe(
       data => { 
        if (data == true) { 
         document.getElementById("ErrorStatus").style.display = "none"; 
         document.getElementById("SucessStatus").style.display = ""; 
         this.SuccessMsg = "Tracker User information was saved successfully."; 
         scrollTo(0, 0); 
        } 
        else { 
         // do nothing 
        } 
       }, 
       error => { 
        if (error.status == 500) { 
         var errorMsg = JSON.parse(error._body); 
         document.getElementById("SucessStatus").style.display = "none"; 
         document.getElementById("ErrorStatus").style.display = ""; 
         this.ErrorMsg = errorMsg.ExceptionMessage; 
         scrollTo(0, 0); 
        } 
        this.CRUDService.logError(error); 
       } 
       ); 

     } 
    } 
    CancelEditUser() { 
     this.router.navigate(['TrackerUserAdmin']); 
    } 


} 
+0

角隊應該更好的測試和文檔測試框架編寫測試:d –

+0

哪個RC版是你使用?最後一個(RC.4) – Dinistro

+0

沒有任何變化。您正在使用beta。*版本。請考慮升級到最新版本(rc.4)。有一些修補程序和東西的掠奪。 – Dinistro

回答

0

f.componentInstance得到所有的方法屬性使用茉莉來測試我的應用程序

beforeEach(injectAsync([TestComponentBuilder], (tcb: TestComponentBuilder) => { 
      return tcb 
       .overrideProviders(EditUserAdmin, [ 
        provide(EditUserService, { useClass: EditUserMock }), 
        provide(APIServiceConstants, { useClass: APIServiceConstants }), 
        provide(RouteParams, { useValue: new RouteParams({ UserId: "48288" }) }), 
        provide(Router, { useClass: MockRouter }) 
       ]) 
       .createAsync(EditUserAdmin) 
       .then((f) => { 
        f.detectChanges(); 
        app = f.componentInstance; 
        fixture = f; 
       }); 
     }));