From d40cf1f01e0257b337e923a1ecfb95aedc6d8ee7 Mon Sep 17 00:00:00 2001 From: Florian Hartwich Date: Tue, 4 Apr 2017 01:10:22 +0200 Subject: [PATCH] Add spec reporter; Add BlogEntry delete button funct test --- project-manager/karma.conf.js | 8 +++- .../blog-entry/blog-entry.component.spec.ts | 40 +++++++++++++++---- .../src/app/blog/blog.component.spec.ts | 5 +-- .../src/app/blog/blog.component.ts | 21 ++++++++-- .../src/app/blog/initialEntries.ts | 16 -------- .../src/app/login/login.component.ts | 1 - .../src/app/test-example/basic-test.spec.ts | 2 +- 7 files changed, 59 insertions(+), 34 deletions(-) delete mode 100644 project-manager/src/app/blog/initialEntries.ts diff --git a/project-manager/karma.conf.js b/project-manager/karma.conf.js index 9f0e343..b51d050 100644 --- a/project-manager/karma.conf.js +++ b/project-manager/karma.conf.js @@ -18,10 +18,16 @@ module.exports = function(config) { plugins: [ require('karma-jasmine'), require('karma-chrome-launcher'), + require('karma-spec-reporter'), require('@angular/cli/plugins/karma') ], + client:{ + clearContext: false // leave Jasmine Spec Runner output visible in browser + }, + + // list of files / patterns to load in the browser files: [ './src/test.ts' @@ -50,7 +56,7 @@ module.exports = function(config) { // test results reporter to use // possible values: 'dots', 'progress' // available reporters: https://npmjs.org/browse/keyword/karma-reporter - reporters: ['progress'], + reporters: ['spec'], // web server port diff --git a/project-manager/src/app/blog/blog-entry/blog-entry.component.spec.ts b/project-manager/src/app/blog/blog-entry/blog-entry.component.spec.ts index 86a7a58..b48ab04 100644 --- a/project-manager/src/app/blog/blog-entry/blog-entry.component.spec.ts +++ b/project-manager/src/app/blog/blog-entry/blog-entry.component.spec.ts @@ -1,17 +1,16 @@ import {TestBed} from "@angular/core/testing"; import {BlogEntryComponent} from "./blog-entry.component"; import {BlogEntry} from "./blog-entry"; +import {BlogComponent} from "../blog.component"; +import {RouterTestingModule} from "@angular/router/testing"; describe('Blog Entry Isolated Test', () => { - beforeEach(() => { + it('should render DOM correctly according to Input', () => { + // Umgebung initialisieren TestBed.configureTestingModule({ declarations: [BlogEntryComponent], - }) - }); - - it('should render DOM correct according to Input', () => { - // Umgebung initialisieren + }); const fixture = TestBed.createComponent(BlogEntryComponent); const blogEntryComponent : BlogEntryComponent = fixture.componentInstance; const element = fixture.nativeElement; @@ -40,8 +39,8 @@ describe('Blog Entry Isolated Test', () => { // textContent statt innerHtml // siehe http://stackoverflow.com/questions/40227533/angular-2-and-jasmine-unit-testing-cannot-get-the-innerhtml - const blogTitle = element.querySelector('div /deep/ .blog-summary > span'); - expect(blogTitle.textContent).toBe(testTitle); + const blogTitle = element.querySelector('div /deep/ .blog-summary > span').textContent; + expect(blogTitle).toBe(testTitle); const blogText = element.querySelector('div /deep/ .blog-summary > p').textContent; expect(blogText).toBe(testText); @@ -58,3 +57,28 @@ describe('Blog Entry Isolated Test', () => { }); }); + +describe('BlogEntryComp -> BlogComp Relational Test', () => { + + it ('should remove entry from BlogComponent on "delete" button click', () => { + TestBed.configureTestingModule({ + imports: [RouterTestingModule.withRoutes([])], + declarations: [BlogEntryComponent, BlogComponent] + }); + + const entryFixture = TestBed.createComponent(BlogEntryComponent); + const entryInstance : BlogEntryComponent = entryFixture.componentInstance; + + const blogFixture = TestBed.createComponent(BlogComponent); + const blogInstance : BlogComponent = blogFixture.componentInstance; + + const blogEntry : BlogEntry = blogInstance.entries[0]; + entryInstance.entry = blogEntry; + entryInstance.blogComponent = blogInstance; + + const oldLength = blogInstance.entries.length; + entryFixture.nativeElement.querySelector('div /deep/ .blog-delete > button').click(); + expect(blogInstance.entries.length).toBe(oldLength - 1); + }); + +}); diff --git a/project-manager/src/app/blog/blog.component.spec.ts b/project-manager/src/app/blog/blog.component.spec.ts index ab216bb..afca773 100644 --- a/project-manager/src/app/blog/blog.component.spec.ts +++ b/project-manager/src/app/blog/blog.component.spec.ts @@ -1,12 +1,11 @@ import {BlogComponent} from './blog.component' -import {Title} from "@angular/platform-browser"; describe('Blog Component Isolated Test', () => { let blogComponent: BlogComponent; beforeEach(() => { - blogComponent = new BlogComponent(null, null, new Title('Project Blog')); + blogComponent = new BlogComponent(null, null, null); }); it('should have initial entries', () => { @@ -25,7 +24,7 @@ describe('Blog Component Isolated Test', () => { blogComponent.createBlogEntry(entryTitle, entryImage, entryText); let newEntry = blogComponent.entries[blogComponent.entries.length - 1]; - expect(newEntry.id - 1).toBe(preCreationId) + expect(newEntry.id - 1).toBe(preCreationId); expect(newEntry.image).toBe(entryImage); expect(newEntry.text).toBe(entryText); expect(newEntry.createdAt.getDate()).toBe(new Date().getDate()); diff --git a/project-manager/src/app/blog/blog.component.ts b/project-manager/src/app/blog/blog.component.ts index acabd6f..f2091ac 100644 --- a/project-manager/src/app/blog/blog.component.ts +++ b/project-manager/src/app/blog/blog.component.ts @@ -1,7 +1,6 @@ import {Component} from '@angular/core'; import {ActivatedRoute, Router} from '@angular/router'; import {Title} from '@angular/platform-browser'; -import {initialEntries} from './initialEntries'; import {BlogEntry} from './blog-entry/blog-entry'; @Component({ @@ -17,9 +16,25 @@ export class BlogComponent { id: number = 0; constructor(r: ActivatedRoute, private router: Router, private titleService: Title) { + const initialEntries = [ + { + id: 1, + title: "Angular 2 erschienen", + image: "", + text: "Endlich ist die finale Version von Angular 2 erschienen. Nach langer Beta-Phase ...", + createdAt: null + }, + { + id: 2, + title: "Neue Vorschläge für die kommende Module-Loader-Syntax", + image: "https://cdn-images-1.medium.com/max/1000/1*RQFLsbQumE-iNrXzs_Oz8g.jpeg", + text: "Nachdem im ES2015-Standard bereits die Module-API verabschiedet wurde, hat das zuständige Konsortium nun neue Vorschläge für die Module-Loader-Syntax bekannt gegeben...", + createdAt : null + } + ]; this.entries = initialEntries; this.entries.forEach((entry)=> { - entry.createdAt = new Date() + entry.createdAt = new Date(); if (this.id < entry.id) { this.id = entry.id; } @@ -28,14 +43,12 @@ export class BlogComponent { createBlogEntry(title:string, image:string, text:string) { this.id++; - console.log(this.id, title, image, text); let entry = new BlogEntry(); entry.id = this.id; entry.title = title; entry.image = image; entry.text = text; entry.createdAt = new Date(); - console.log(this.entries); this.entries.push(entry); } diff --git a/project-manager/src/app/blog/initialEntries.ts b/project-manager/src/app/blog/initialEntries.ts deleted file mode 100644 index 41700b9..0000000 --- a/project-manager/src/app/blog/initialEntries.ts +++ /dev/null @@ -1,16 +0,0 @@ -export var initialEntries = [ - { - id: 1, - title: "Angular 2 erschienen", - image: "", - text: "Endlich ist die finale Version von Angular 2 erschienen. Nach langer Beta-Phase ...", - createdAt: null - }, - { - id: 2, - title: "Neue Vorschläge für die kommende Module-Loader-Syntax", - image: "https://cdn-images-1.medium.com/max/1000/1*RQFLsbQumE-iNrXzs_Oz8g.jpeg", - text: "Nachdem im ES2015-Standard bereits die Module-API verabschiedet wurde, hat das zuständige Konsortium nun neue Vorschläge für die Module-Loader-Syntax bekannt gegeben...", - createdAt : null - } -]; diff --git a/project-manager/src/app/login/login.component.ts b/project-manager/src/app/login/login.component.ts index cf5c838..0907a86 100644 --- a/project-manager/src/app/login/login.component.ts +++ b/project-manager/src/app/login/login.component.ts @@ -13,7 +13,6 @@ export class LoginComponent { constructor(private loginService: LoginService, private router: Router, private route: ActivatedRoute) { - } login(userName: string, password: string) { diff --git a/project-manager/src/app/test-example/basic-test.spec.ts b/project-manager/src/app/test-example/basic-test.spec.ts index 474149e..be3b82d 100644 --- a/project-manager/src/app/test-example/basic-test.spec.ts +++ b/project-manager/src/app/test-example/basic-test.spec.ts @@ -1,5 +1,5 @@ // Test Suite -describe('Basic test', () => { +describe('Basic Test', () => { // Variablendeklaration zur Verwendung in mehreren Testfällen let someInt;