build(docs-infra): fix linting warnings (#42359)
This commit fixes some linting warning that were printed when running `ng lint`. The warnings can be seen in the `lint` step of [this CI job][1]. Most of the warnings were related to the deprecation of passing context to Jasmine matchers in favor of using the [withContext()][2] matcher (introduced in Jasmine v3.3.0). [1]: https://circleci.com/gh/angular/angular/995543 [2]: https://jasmine.github.io/api/3.3/matchers.html#withContext PR Close #42359
This commit is contained in:
parent
62b5a6cb07
commit
e798bfabb0
|
@ -1120,8 +1120,9 @@ describe('AppComponent', () => {
|
||||||
const host = fixture.debugElement;
|
const host = fixture.debugElement;
|
||||||
const classes: string = host.properties.className;
|
const classes: string = host.properties.className;
|
||||||
const classArray = classes.split(' ').filter(c => c.indexOf(`${type}-`) === 0);
|
const classArray = classes.split(' ').filter(c => c.indexOf(`${type}-`) === 0);
|
||||||
expect(classArray.length).toBeLessThanOrEqual(1, `"${classes}" should have only one class matching ${type}-*`);
|
expect(classArray.length).withContext(`"${classes}" should have only one class matching ${type}-*`)
|
||||||
expect(classArray).toEqual([`${type}-${value}`], `"${classes}" should contain ${type}-${value}`);
|
.toBeLessThanOrEqual(1);
|
||||||
|
expect(classArray).withContext(`"${classes}" should contain ${type}-${value}`).toEqual([`${type}-${value}`]);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -37,8 +37,8 @@ describe('ApiListComponent', () => {
|
||||||
function expectFilteredResult(label: string, itemTest: (item: ApiItem) => boolean) {
|
function expectFilteredResult(label: string, itemTest: (item: ApiItem) => boolean) {
|
||||||
component.filteredSections.subscribe(filtered => {
|
component.filteredSections.subscribe(filtered => {
|
||||||
filtered = filtered.filter(section => section.items);
|
filtered = filtered.filter(section => section.items);
|
||||||
expect(filtered.length).toBeGreaterThan(0, 'expected something');
|
expect(filtered.length).withContext('expected something').toBeGreaterThan(0);
|
||||||
expect(filtered.every(section => section.items?.every(itemTest))).toBe(true, label);
|
expect(filtered.every(section => section.items?.every(itemTest))).withContext(label).toBe(true);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,7 +64,7 @@ describe('ApiListComponent', () => {
|
||||||
component.setQuery('core');
|
component.setQuery('core');
|
||||||
component.filteredSections.subscribe(filtered => {
|
component.filteredSections.subscribe(filtered => {
|
||||||
filtered = filtered.filter(section => Array.isArray(section.items));
|
filtered = filtered.filter(section => Array.isArray(section.items));
|
||||||
expect(filtered.length).toBe(1, 'only one section');
|
expect(filtered.length).withContext('only one section').toBe(1);
|
||||||
expect(filtered[0].name).toBe('core');
|
expect(filtered[0].name).toBe('core');
|
||||||
expect(filtered[0].items).toEqual(sections.find(section => section.name === 'core')?.items as ApiItem[]);
|
expect(filtered[0].items).toEqual(sections.find(section => section.name === 'core')?.items as ApiItem[]);
|
||||||
});
|
});
|
||||||
|
@ -115,17 +115,17 @@ describe('ApiListComponent', () => {
|
||||||
|
|
||||||
component.filteredSections.subscribe(filtered => {
|
component.filteredSections.subscribe(filtered => {
|
||||||
filtered = filtered.filter(s => s.items);
|
filtered = filtered.filter(s => s.items);
|
||||||
expect(filtered.length).toBe(1, 'sections');
|
expect(filtered.length).withContext('sections').toBe(1);
|
||||||
expect(filtered[0].name).toBe(section, 'section name');
|
expect(filtered[0].name).withContext('section name').toBe(section);
|
||||||
const items = filtered[0].items as ApiItem[];
|
const items = filtered[0].items as ApiItem[];
|
||||||
expect(items.length).toBe(1, 'items');
|
expect(items.length).withContext('items').toBe(1);
|
||||||
|
|
||||||
const item = items[0];
|
const item = items[0];
|
||||||
const badItem = 'Wrong item: ' + JSON.stringify(item, null, 2);
|
const badItem = 'Wrong item: ' + JSON.stringify(item, null, 2);
|
||||||
|
|
||||||
expect(item.docType).toBe(type, badItem);
|
expect(item.docType).withContext(badItem).toBe(type);
|
||||||
expect(item.stability).toBe(stability, badItem);
|
expect(item.stability).withContext(badItem).toBe(stability);
|
||||||
expect(item.name).toBe(name, badItem);
|
expect(item.name).withContext(badItem).toBe(name);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -104,7 +104,7 @@ describe('ApiService', () => {
|
||||||
// called twice during this test
|
// called twice during this test
|
||||||
// (1) during subscribe
|
// (1) during subscribe
|
||||||
// (2) after refresh
|
// (2) after refresh
|
||||||
expect(sections).toEqual(data, 'call ' + call++);
|
expect(sections).withContext('call ' + call++).toEqual(data);
|
||||||
});
|
});
|
||||||
|
|
||||||
httpMock.expectOne({}).flush(data);
|
httpMock.expectOne({}).flush(data);
|
||||||
|
@ -114,7 +114,7 @@ describe('ApiService', () => {
|
||||||
service.fetchSections();
|
service.fetchSections();
|
||||||
httpMock.expectOne({}).flush(data);
|
httpMock.expectOne({}).flush(data);
|
||||||
|
|
||||||
expect(call).toBe(2, 'should be called twice');
|
expect(call).withContext('should be called twice').toBe(2);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -48,7 +48,8 @@ describe('CodeTabsComponent', () => {
|
||||||
// Second code pane expectations
|
// Second code pane expectations
|
||||||
expect(tabs[1].class).toBe('class-B');
|
expect(tabs[1].class).toBe('class-B');
|
||||||
expect(tabs[1].language).toBe('language-B');
|
expect(tabs[1].language).toBe('language-B');
|
||||||
expect(tabs[1].linenums).toBe('default-linenums', 'Default linenums should have been used');
|
expect(tabs[1].linenums).withContext('Default linenums should have been used')
|
||||||
|
.toBe('default-linenums');
|
||||||
expect(tabs[1].path).toBe('path-B');
|
expect(tabs[1].path).toBe('path-B');
|
||||||
expect(tabs[1].region).toBe('region-B');
|
expect(tabs[1].region).toBe('region-B');
|
||||||
expect(tabs[1].header).toBe('header-B');
|
expect(tabs[1].header).toBe('header-B');
|
||||||
|
|
|
@ -159,7 +159,7 @@ describe('CodeComponent', () => {
|
||||||
|
|
||||||
// `<li>`s are a tell-tale for line numbers
|
// `<li>`s are a tell-tale for line numbers
|
||||||
const lis = fixture.nativeElement.querySelectorAll('li');
|
const lis = fixture.nativeElement.querySelectorAll('li');
|
||||||
expect(lis.length).toBe(0, 'should be no linenums');
|
expect(lis.length).withContext('should be no linenums').toBe(0);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -171,7 +171,7 @@ describe('CodeComponent', () => {
|
||||||
}
|
}
|
||||||
|
|
||||||
it('should not display "code-missing" class when there is some code', () => {
|
it('should not display "code-missing" class when there is some code', () => {
|
||||||
expect(getErrorMessage()).toBeNull('should not have element with "code-missing" class');
|
expect(getErrorMessage()).withContext('should not have element with "code-missing" class').toBeNull();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should display error message when there is no code (after trimming)', () => {
|
it('should display error message when there is no code (after trimming)', () => {
|
||||||
|
@ -232,16 +232,16 @@ describe('CodeComponent', () => {
|
||||||
it('should call copier service when clicked', () => {
|
it('should call copier service when clicked', () => {
|
||||||
const clipboard = TestBed.inject(Clipboard);
|
const clipboard = TestBed.inject(Clipboard);
|
||||||
const spy = spyOn(clipboard, 'copy');
|
const spy = spyOn(clipboard, 'copy');
|
||||||
expect(spy.calls.count()).toBe(0, 'before click');
|
expect(spy.calls.count()).withContext('before click').toBe(0);
|
||||||
getButton().click();
|
getButton().click();
|
||||||
expect(spy.calls.count()).toBe(1, 'after click');
|
expect(spy.calls.count()).withContext('after click').toBe(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should copy code text when clicked', () => {
|
it('should copy code text when clicked', () => {
|
||||||
const clipboard = TestBed.inject(Clipboard);
|
const clipboard = TestBed.inject(Clipboard);
|
||||||
const spy = spyOn(clipboard, 'copy');
|
const spy = spyOn(clipboard, 'copy');
|
||||||
getButton().click();
|
getButton().click();
|
||||||
expect(spy.calls.argsFor(0)[0]).toBe(oneLineCode, 'after click');
|
expect(spy.calls.argsFor(0)[0]).withContext('after click').toBe(oneLineCode);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should preserve newlines in the copied code', () => {
|
it('should preserve newlines in the copied code', () => {
|
||||||
|
@ -258,7 +258,7 @@ describe('CodeComponent', () => {
|
||||||
getButton().click();
|
getButton().click();
|
||||||
actualCode = spy.calls.mostRecent().args[0];
|
actualCode = spy.calls.mostRecent().args[0];
|
||||||
|
|
||||||
expect(actualCode).toBe(expectedCode, `when linenums=${linenums}`);
|
expect(actualCode).withContext(`when linenums=${linenums}`).toBe(expectedCode);
|
||||||
expect(actualCode.match(/\r?\n/g)?.length).toBe(5);
|
expect(actualCode.match(/\r?\n/g)?.length).toBe(5);
|
||||||
|
|
||||||
spy.calls.reset();
|
spy.calls.reset();
|
||||||
|
|
|
@ -44,7 +44,7 @@ describe('ContributorService', () => {
|
||||||
it('contributors observable should complete', () => {
|
it('contributors observable should complete', () => {
|
||||||
let completed = false;
|
let completed = false;
|
||||||
contribService.contributors.subscribe({complete: () => completed = true});
|
contribService.contributors.subscribe({complete: () => completed = true});
|
||||||
expect(completed).toBe(true, 'observable completed');
|
expect(completed).withContext('observable completed').toBe(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should reshape the contributor json to expected result', () => {
|
it('should reshape the contributor json to expected result', () => {
|
||||||
|
|
|
@ -65,7 +65,7 @@ describe('LiveExampleComponent', () => {
|
||||||
|
|
||||||
it('should create LiveExampleComponent', () => {
|
it('should create LiveExampleComponent', () => {
|
||||||
testComponent(() => {
|
testComponent(() => {
|
||||||
expect(liveExampleComponent).toBeTruthy('LiveExampleComponent');
|
expect(liveExampleComponent).withContext('LiveExampleComponent').toBeTruthy();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -138,7 +138,7 @@ describe('LiveExampleComponent', () => {
|
||||||
setHostTemplate('<live-example noDownload></live-example>');
|
setHostTemplate('<live-example noDownload></live-example>');
|
||||||
testComponent(() => {
|
testComponent(() => {
|
||||||
const hrefs = getHrefs();
|
const hrefs = getHrefs();
|
||||||
expect(hrefs.length).toBe(1, 'only the stackblitz live-example anchor');
|
expect(hrefs.length).withContext('only the stackblitz live-example anchor').toBe(1);
|
||||||
expect(hrefs[0]).toContain('stackblitz.html');
|
expect(hrefs[0]).toContain('stackblitz.html');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -147,7 +147,7 @@ describe('LiveExampleComponent', () => {
|
||||||
setHostTemplate('<live-example downloadOnly>download this</live-example>');
|
setHostTemplate('<live-example downloadOnly>download this</live-example>');
|
||||||
testComponent(() => {
|
testComponent(() => {
|
||||||
const hrefs = getHrefs();
|
const hrefs = getHrefs();
|
||||||
expect(hrefs.length).toBe(1, 'only the zip anchor');
|
expect(hrefs.length).withContext('only the zip anchor').toBe(1);
|
||||||
expect(hrefs[0]).toContain('.zip'); });
|
expect(hrefs[0]).toContain('.zip'); });
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -156,8 +156,8 @@ describe('LiveExampleComponent', () => {
|
||||||
testComponent(() => {
|
testComponent(() => {
|
||||||
const expectedTitle = 'live example';
|
const expectedTitle = 'live example';
|
||||||
const anchor = getLiveExampleAnchor();
|
const anchor = getLiveExampleAnchor();
|
||||||
expect(anchor.textContent).toBe(expectedTitle, 'anchor content');
|
expect(anchor.textContent).withContext('anchor content').toBe(expectedTitle);
|
||||||
expect(anchor.getAttribute('title')).toBe(expectedTitle, 'title');
|
expect(anchor.getAttribute('title')).withContext('title').toBe(expectedTitle);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -166,8 +166,8 @@ describe('LiveExampleComponent', () => {
|
||||||
setHostTemplate(`<live-example title="${expectedTitle}"></live-example>`);
|
setHostTemplate(`<live-example title="${expectedTitle}"></live-example>`);
|
||||||
testComponent(() => {
|
testComponent(() => {
|
||||||
const anchor = getLiveExampleAnchor();
|
const anchor = getLiveExampleAnchor();
|
||||||
expect(anchor.textContent).toBe(expectedTitle, 'anchor content');
|
expect(anchor.textContent).withContext('anchor content').toBe(expectedTitle);
|
||||||
expect(anchor.getAttribute('title')).toBe(expectedTitle, 'title');
|
expect(anchor.getAttribute('title')).withContext('title').toBe(expectedTitle);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -176,8 +176,8 @@ describe('LiveExampleComponent', () => {
|
||||||
setHostTemplate(`<live-example title="ignore this title">${expectedTitle}</live-example>`);
|
setHostTemplate(`<live-example title="ignore this title">${expectedTitle}</live-example>`);
|
||||||
testComponent(() => {
|
testComponent(() => {
|
||||||
const anchor = getLiveExampleAnchor();
|
const anchor = getLiveExampleAnchor();
|
||||||
expect(anchor.textContent).toBe(expectedTitle, 'anchor content');
|
expect(anchor.textContent).withContext('anchor content').toBe(expectedTitle);
|
||||||
expect(anchor.getAttribute('title')).toBe(expectedTitle, 'title');
|
expect(anchor.getAttribute('title')).withContext('title').toBe(expectedTitle);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -206,8 +206,8 @@ describe('LiveExampleComponent', () => {
|
||||||
it('should have hidden, embedded stackblitz', () => {
|
it('should have hidden, embedded stackblitz', () => {
|
||||||
setHostTemplate('<live-example embedded></live-example>');
|
setHostTemplate('<live-example embedded></live-example>');
|
||||||
testComponent(() => {
|
testComponent(() => {
|
||||||
expect(liveExampleComponent.mode).toBe('embedded', 'component is embedded');
|
expect(liveExampleComponent.mode).withContext('component is embedded').toBe('embedded');
|
||||||
expect(getEmbeddedStackblitzComponent()).toBeTruthy('EmbeddedStackblitzComponent');
|
expect(getEmbeddedStackblitzComponent()).withContext('EmbeddedStackblitzComponent').toBeTruthy();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,7 @@ describe('ResourceService', () => {
|
||||||
it('categories observable should complete', () => {
|
it('categories observable should complete', () => {
|
||||||
let completed = false;
|
let completed = false;
|
||||||
resourceService.categories.subscribe({complete: () => completed = true});
|
resourceService.categories.subscribe({complete: () => completed = true});
|
||||||
expect(completed).toBe(true, 'observable completed');
|
expect(completed).withContext('observable completed').toBe(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should reshape contributors.json to sorted category array', () => {
|
it('should reshape contributors.json to sorted category array', () => {
|
||||||
|
@ -58,17 +58,17 @@ describe('ResourceService', () => {
|
||||||
const sub = cat.subCategories[0];
|
const sub = cat.subCategories[0];
|
||||||
const res = sub.resources[0];
|
const res = sub.resources[0];
|
||||||
|
|
||||||
expect(cat.id).toBe('cat-3', 'category id');
|
expect(cat.id).withContext('category id').toBe('cat-3');
|
||||||
expect(sub.id).toBe('cat3-subcat2', 'subcat id');
|
expect(sub.id).withContext('subcat id').toBe('cat3-subcat2');
|
||||||
expect(res.id).toBe('cat3-subcat2-res1', 'resources id');
|
expect(res.id).withContext('resources id').toBe('cat3-subcat2-res1');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('resource knows its category and sub-category titles', () => {
|
it('resource knows its category and sub-category titles', () => {
|
||||||
const cat = categories[1];
|
const cat = categories[1];
|
||||||
const sub = cat.subCategories[0];
|
const sub = cat.subCategories[0];
|
||||||
const res = sub.resources[0];
|
const res = sub.resources[0];
|
||||||
expect(res.category).toBe(cat.title, 'category title');
|
expect(res.category).withContext('category title').toBe(cat.title);
|
||||||
expect(res.subCategory).toBe(sub.title, 'subcategory title');
|
expect(res.subCategory).withContext('subcategory title').toBe(sub.title);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should have expected SubCategories of "Cat 3"', () => {
|
it('should have expected SubCategories of "Cat 3"', () => {
|
||||||
|
|
|
@ -122,12 +122,12 @@ describe('TocComponent', () => {
|
||||||
it('should not have secondary items', () => {
|
it('should not have secondary items', () => {
|
||||||
expect(tocComponent.type).toEqual('EmbeddedSimple');
|
expect(tocComponent.type).toEqual('EmbeddedSimple');
|
||||||
const aSecond = page.listItems.find(item => item.classes.secondary);
|
const aSecond = page.listItems.find(item => item.classes.secondary);
|
||||||
expect(aSecond).toBeFalsy('should not find a secondary');
|
expect(aSecond).withContext('should not find a secondary').toBeFalsy();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should not display expando buttons', () => {
|
it('should not display expando buttons', () => {
|
||||||
expect(page.tocHeadingButtonEmbedded).toBeFalsy('top expand/collapse button');
|
expect(page.tocHeadingButtonEmbedded).withContext('top expand/collapse button').toBeFalsy();
|
||||||
expect(page.tocMoreButton).toBeFalsy('bottom more button');
|
expect(page.tocMoreButton).withContext('bottom more button').toBeFalsy();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -145,7 +145,7 @@ describe('TocComponent', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should not display the h1 item', () => {
|
it('should not display the h1 item', () => {
|
||||||
expect(page.listItems.find(item => item.classes.h1)).toBeFalsy('should not find h1 item');
|
expect(page.listItems.find(item => item.classes.h1)).withContext('should not find h1 item').toBeFalsy();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should be in "collapsed" (not expanded) state at the start', () => {
|
it('should be in "collapsed" (not expanded) state at the start', () => {
|
||||||
|
@ -157,8 +157,8 @@ describe('TocComponent', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should display expando buttons', () => {
|
it('should display expando buttons', () => {
|
||||||
expect(page.tocHeadingButtonEmbedded).toBeTruthy('top expand/collapse button');
|
expect(page.tocHeadingButtonEmbedded).withContext('top expand/collapse button').toBeTruthy();
|
||||||
expect(page.tocMoreButton).toBeTruthy('bottom more button');
|
expect(page.tocMoreButton).withContext('bottom more button').toBeTruthy();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should have secondary items', () => {
|
it('should have secondary items', () => {
|
||||||
|
@ -168,7 +168,7 @@ describe('TocComponent', () => {
|
||||||
// CSS will hide items with the secondary class when collapsed
|
// CSS will hide items with the secondary class when collapsed
|
||||||
it('should have secondary item with a secondary class', () => {
|
it('should have secondary item with a secondary class', () => {
|
||||||
const aSecondary = page.listItems.find(item => item.classes.secondary);
|
const aSecondary = page.listItems.find(item => item.classes.secondary);
|
||||||
expect(aSecondary).toBeTruthy('should find a secondary');
|
expect(aSecondary).withContext('should find a secondary').toBeTruthy();
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('after click tocHeading button', () => {
|
describe('after click tocHeading button', () => {
|
||||||
|
@ -270,12 +270,12 @@ describe('TocComponent', () => {
|
||||||
it('should not have secondary items', () => {
|
it('should not have secondary items', () => {
|
||||||
expect(tocComponent.type).toEqual('Floating');
|
expect(tocComponent.type).toEqual('Floating');
|
||||||
const aSecond = page.listItems.find(item => item.classes.secondary);
|
const aSecond = page.listItems.find(item => item.classes.secondary);
|
||||||
expect(aSecond).toBeFalsy('should not find a secondary');
|
expect(aSecond).withContext('should not find a secondary').toBeFalsy();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should not display expando buttons', () => {
|
it('should not display expando buttons', () => {
|
||||||
expect(page.tocHeadingButtonEmbedded).toBeFalsy('top expand/collapse button');
|
expect(page.tocHeadingButtonEmbedded).withContext('top expand/collapse button').toBeFalsy();
|
||||||
expect(page.tocMoreButton).toBeFalsy('bottom more button');
|
expect(page.tocMoreButton).withContext('bottom more button').toBeFalsy();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should display H1 title', () => {
|
it('should display H1 title', () => {
|
||||||
|
|
|
@ -74,21 +74,21 @@ describe('NavItemComponent', () => {
|
||||||
it('should de-select if previously selected', () => {
|
it('should de-select if previously selected', () => {
|
||||||
component.isSelected = true;
|
component.isSelected = true;
|
||||||
onChanges();
|
onChanges();
|
||||||
expect(component.isSelected).toBe(false, 'becomes de-selected');
|
expect(component.isSelected).withContext('becomes de-selected').toBe(false);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should collapse if previously expanded in narrow mode', () => {
|
it('should collapse if previously expanded in narrow mode', () => {
|
||||||
component.isWide = false;
|
component.isWide = false;
|
||||||
component.isExpanded = true;
|
component.isExpanded = true;
|
||||||
onChanges();
|
onChanges();
|
||||||
expect(component.isExpanded).toBe(false, 'becomes collapsed');
|
expect(component.isExpanded).withContext('becomes collapsed').toBe(false);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should remain expanded in wide mode', () => {
|
it('should remain expanded in wide mode', () => {
|
||||||
component.isWide = true;
|
component.isWide = true;
|
||||||
component.isExpanded = true;
|
component.isExpanded = true;
|
||||||
onChanges();
|
onChanges();
|
||||||
expect(component.isExpanded).toBe(true, 'remains expanded');
|
expect(component.isExpanded).withContext('remains expanded').toBe(true);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -100,17 +100,17 @@ describe('NavItemComponent', () => {
|
||||||
it('should select when previously not selected', () => {
|
it('should select when previously not selected', () => {
|
||||||
component.isSelected = false;
|
component.isSelected = false;
|
||||||
onChanges();
|
onChanges();
|
||||||
expect(component.isSelected).toBe(true, 'becomes selected');
|
expect(component.isSelected).withContext('becomes selected').toBe(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should expand the current node or keep it expanded', () => {
|
it('should expand the current node or keep it expanded', () => {
|
||||||
component.isExpanded = false;
|
component.isExpanded = false;
|
||||||
onChanges();
|
onChanges();
|
||||||
expect(component.isExpanded).toBe(true, 'becomes true');
|
expect(component.isExpanded).withContext('becomes true').toBe(true);
|
||||||
|
|
||||||
component.isExpanded = true;
|
component.isExpanded = true;
|
||||||
onChanges();
|
onChanges();
|
||||||
expect(component.isExpanded).toBe(true, 'remains true');
|
expect(component.isExpanded).withContext('remains true').toBe(true);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -122,17 +122,17 @@ describe('NavItemComponent', () => {
|
||||||
it('should select when previously not selected', () => {
|
it('should select when previously not selected', () => {
|
||||||
component.isSelected = false;
|
component.isSelected = false;
|
||||||
onChanges();
|
onChanges();
|
||||||
expect(component.isSelected).toBe(true, 'becomes selected');
|
expect(component.isSelected).withContext('becomes selected').toBe(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should always expand this header', () => {
|
it('should always expand this header', () => {
|
||||||
component.isExpanded = false;
|
component.isExpanded = false;
|
||||||
onChanges();
|
onChanges();
|
||||||
expect(component.isExpanded).toBe(true, 'becomes expanded');
|
expect(component.isExpanded).withContext('becomes expanded').toBe(true);
|
||||||
|
|
||||||
component.isExpanded = false;
|
component.isExpanded = false;
|
||||||
onChanges();
|
onChanges();
|
||||||
expect(component.isExpanded).toBe(true, 'stays expanded');
|
expect(component.isExpanded).withContext('stays expanded').toBe(true);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -142,23 +142,23 @@ describe('NavItemComponent', () => {
|
||||||
it('should expand when headerClicked() and previously collapsed', () => {
|
it('should expand when headerClicked() and previously collapsed', () => {
|
||||||
component.isExpanded = false;
|
component.isExpanded = false;
|
||||||
component.headerClicked();
|
component.headerClicked();
|
||||||
expect(component.isExpanded).toBe(true, 'should be expanded');
|
expect(component.isExpanded).withContext('should be expanded').toBe(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should collapse when headerClicked() and previously expanded', () => {
|
it('should collapse when headerClicked() and previously expanded', () => {
|
||||||
component.isExpanded = true;
|
component.isExpanded = true;
|
||||||
component.headerClicked();
|
component.headerClicked();
|
||||||
expect(component.isExpanded).toBe(false, 'should be collapsed');
|
expect(component.isExpanded).withContext('should be collapsed').toBe(false);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should not change isSelected when headerClicked()', () => {
|
it('should not change isSelected when headerClicked()', () => {
|
||||||
component.isSelected = true;
|
component.isSelected = true;
|
||||||
component.headerClicked();
|
component.headerClicked();
|
||||||
expect(component.isSelected).toBe(true, 'remains selected');
|
expect(component.isSelected).withContext('remains selected').toBe(true);
|
||||||
|
|
||||||
component.isSelected = false;
|
component.isSelected = false;
|
||||||
component.headerClicked();
|
component.headerClicked();
|
||||||
expect(component.isSelected).toBe(false, 'remains not selected');
|
expect(component.isSelected).withContext('remains not selected').toBe(false);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should set classes', () => {
|
it('should set classes', () => {
|
||||||
|
@ -201,14 +201,14 @@ describe('NavItemComponent', () => {
|
||||||
component.ngOnChanges(); // assume component.ngOnChanges ignores arguments
|
component.ngOnChanges(); // assume component.ngOnChanges ignores arguments
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
let children = fixture.debugElement.queryAll(By.directive(NavItemComponent));
|
let children = fixture.debugElement.queryAll(By.directive(NavItemComponent));
|
||||||
expect(children.length).toEqual(2, 'when IsWide is true');
|
expect(children.length).withContext('when IsWide is true').toEqual(2);
|
||||||
children.forEach(child => expect(child.componentInstance.isWide).toBe(true));
|
children.forEach(child => expect(child.componentInstance.isWide).toBe(true));
|
||||||
|
|
||||||
component.isWide = false;
|
component.isWide = false;
|
||||||
component.ngOnChanges();
|
component.ngOnChanges();
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
children = fixture.debugElement.queryAll(By.directive(NavItemComponent));
|
children = fixture.debugElement.queryAll(By.directive(NavItemComponent));
|
||||||
expect(children.length).toEqual(2, 'when IsWide is false');
|
expect(children.length).withContext('when IsWide is false').toEqual(2);
|
||||||
children.forEach(child => expect(child.componentInstance.isWide).toBe(false));
|
children.forEach(child => expect(child.componentInstance.isWide).toBe(false));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -50,7 +50,7 @@ describe('NavigationService', () => {
|
||||||
navService.navigationViews.subscribe({complete: () => completed = true});
|
navService.navigationViews.subscribe({complete: () => completed = true});
|
||||||
|
|
||||||
httpMock.expectOne({method: 'get', url: navigationPath}).flush({});
|
httpMock.expectOne({method: 'get', url: navigationPath}).flush({});
|
||||||
expect(completed).toBe(true, 'observable completed');
|
expect(completed).withContext('observable completed').toBe(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return the same object to all subscribers', () => {
|
it('should return the same object to all subscribers', () => {
|
||||||
|
@ -209,16 +209,16 @@ describe('NavigationService', () => {
|
||||||
};
|
};
|
||||||
|
|
||||||
locationService.go('c');
|
locationService.go('c');
|
||||||
expect(currentNodes).toEqual(cnode, 'location: c');
|
expect(currentNodes).withContext('location: c').toEqual(cnode);
|
||||||
|
|
||||||
locationService.go('c#foo');
|
locationService.go('c#foo');
|
||||||
expect(currentNodes).toEqual(cnode, 'location: c#foo');
|
expect(currentNodes).withContext('location: c#foo').toEqual(cnode);
|
||||||
|
|
||||||
locationService.go('c?foo=1');
|
locationService.go('c?foo=1');
|
||||||
expect(currentNodes).toEqual(cnode, 'location: c?foo=1');
|
expect(currentNodes).withContext('location: c?foo=1').toEqual(cnode);
|
||||||
|
|
||||||
locationService.go('c#foo?bar=1&baz=2');
|
locationService.go('c#foo?bar=1&baz=2');
|
||||||
expect(currentNodes).toEqual(cnode, 'location: c#foo?bar=1&baz=2');
|
expect(currentNodes).withContext('location: c#foo?bar=1&baz=2').toEqual(cnode);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -279,7 +279,7 @@ describe('LocationService', () => {
|
||||||
service.currentUrl.subscribe(u => url = u);
|
service.currentUrl.subscribe(u => url = u);
|
||||||
|
|
||||||
service.go('');
|
service.go('');
|
||||||
expect(url).toEqual(initialUrl, 'should not have re-navigated locally');
|
expect(url).withContext('should not have re-navigated locally').toEqual(initialUrl);
|
||||||
expect(goExternalSpy).not.toHaveBeenCalled();
|
expect(goExternalSpy).not.toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -331,7 +331,7 @@ describe('LocationService', () => {
|
||||||
spyOn(service, 'goExternal');
|
spyOn(service, 'goExternal');
|
||||||
service.currentUrl.subscribe(url => localUrl = url);
|
service.currentUrl.subscribe(url => localUrl = url);
|
||||||
service.go('https://some/far/away/land');
|
service.go('https://some/far/away/land');
|
||||||
expect(localUrl).toBeFalsy('should not set local url');
|
expect(localUrl).withContext('should not set local url').toBeFalsy();
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@ -537,27 +537,27 @@ describe('LocationService', () => {
|
||||||
anchor.href = 'cat-photo.png';
|
anchor.href = 'cat-photo.png';
|
||||||
let result = service.handleAnchorClick(anchor);
|
let result = service.handleAnchorClick(anchor);
|
||||||
expect(service.go).not.toHaveBeenCalled();
|
expect(service.go).not.toHaveBeenCalled();
|
||||||
expect(result).toBe(true, 'png');
|
expect(result).withContext('png').toBe(true);
|
||||||
|
|
||||||
anchor.href = 'cat-photo.gif';
|
anchor.href = 'cat-photo.gif';
|
||||||
result = service.handleAnchorClick(anchor);
|
result = service.handleAnchorClick(anchor);
|
||||||
expect(service.go).not.toHaveBeenCalled();
|
expect(service.go).not.toHaveBeenCalled();
|
||||||
expect(result).toBe(true, 'gif');
|
expect(result).withContext('gif').toBe(true);
|
||||||
|
|
||||||
anchor.href = 'cat-photo.jpg';
|
anchor.href = 'cat-photo.jpg';
|
||||||
result = service.handleAnchorClick(anchor);
|
result = service.handleAnchorClick(anchor);
|
||||||
expect(service.go).not.toHaveBeenCalled();
|
expect(service.go).not.toHaveBeenCalled();
|
||||||
expect(result).toBe(true, 'jpg');
|
expect(result).withContext('jpg').toBe(true);
|
||||||
|
|
||||||
anchor.href = 'dog-bark.mp3';
|
anchor.href = 'dog-bark.mp3';
|
||||||
result = service.handleAnchorClick(anchor);
|
result = service.handleAnchorClick(anchor);
|
||||||
expect(service.go).not.toHaveBeenCalled();
|
expect(service.go).not.toHaveBeenCalled();
|
||||||
expect(result).toBe(true, 'mp3');
|
expect(result).withContext('mp3').toBe(true);
|
||||||
|
|
||||||
anchor.href = 'pet-tricks.mp4';
|
anchor.href = 'pet-tricks.mp4';
|
||||||
result = service.handleAnchorClick(anchor);
|
result = service.handleAnchorClick(anchor);
|
||||||
expect(service.go).not.toHaveBeenCalled();
|
expect(service.go).not.toHaveBeenCalled();
|
||||||
expect(result).toBe(true, 'mp4');
|
expect(result).withContext('mp4').toBe(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('url has any extension', () => {
|
it('url has any extension', () => {
|
||||||
|
@ -583,14 +583,14 @@ describe('LocationService', () => {
|
||||||
it('should call locationChanged with initial URL', () => {
|
it('should call locationChanged with initial URL', () => {
|
||||||
const initialUrl = location.path().replace(/^\/+/, ''); // strip leading slashes
|
const initialUrl = location.path().replace(/^\/+/, ''); // strip leading slashes
|
||||||
|
|
||||||
expect(gaLocationChanged.calls.count()).toBe(1, 'gaService.locationChanged');
|
expect(gaLocationChanged.calls.count()).withContext('gaService.locationChanged').toBe(1);
|
||||||
const args = gaLocationChanged.calls.first().args;
|
const args = gaLocationChanged.calls.first().args;
|
||||||
expect(args[0]).toBe(initialUrl);
|
expect(args[0]).toBe(initialUrl);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should call locationChanged when `go` to a page', () => {
|
it('should call locationChanged when `go` to a page', () => {
|
||||||
service.go('some-new-url');
|
service.go('some-new-url');
|
||||||
expect(gaLocationChanged.calls.count()).toBe(2, 'gaService.locationChanged');
|
expect(gaLocationChanged.calls.count()).withContext('gaService.locationChanged').toBe(2);
|
||||||
const args = gaLocationChanged.calls.argsFor(1);
|
const args = gaLocationChanged.calls.argsFor(1);
|
||||||
expect(args[0]).toBe('some-new-url');
|
expect(args[0]).toBe('some-new-url');
|
||||||
});
|
});
|
||||||
|
@ -601,16 +601,16 @@ describe('LocationService', () => {
|
||||||
service.go('some-new-url#one');
|
service.go('some-new-url#one');
|
||||||
service.go('some-new-url#two');
|
service.go('some-new-url#two');
|
||||||
service.go('some-new-url/?foo="true"');
|
service.go('some-new-url/?foo="true"');
|
||||||
expect(gaLocationChanged.calls.count()).toBe(4, 'gaService.locationChanged called');
|
expect(gaLocationChanged.calls.count()).withContext('gaService.locationChanged called').toBe(4);
|
||||||
const args = gaLocationChanged.calls.allArgs();
|
const args = gaLocationChanged.calls.allArgs();
|
||||||
expect(args[1]).toEqual(args[2], 'same url for hash calls');
|
expect(args[1]).withContext('same url for hash calls').toEqual(args[2]);
|
||||||
expect(args[1]).toEqual(args[3], 'same url for query string call');
|
expect(args[1]).withContext('same url for query string call').toEqual(args[3]);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should call locationChanged when window history changes', () => {
|
it('should call locationChanged when window history changes', () => {
|
||||||
location.simulatePopState('/next-url');
|
location.simulatePopState('/next-url');
|
||||||
|
|
||||||
expect(gaLocationChanged.calls.count()).toBe(2, 'gaService.locationChanged');
|
expect(gaLocationChanged.calls.count()).withContext('gaService.locationChanged').toBe(2);
|
||||||
const args = gaLocationChanged.calls.argsFor(1);
|
const args = gaLocationChanged.calls.argsFor(1);
|
||||||
expect(args[0]).toBe('next-url');
|
expect(args[0]).toBe('next-url');
|
||||||
});
|
});
|
||||||
|
|
|
@ -282,14 +282,14 @@ describe('TocService', () => {
|
||||||
it('should ignore HTML in heading when calculating id', () => {
|
it('should ignore HTML in heading when calculating id', () => {
|
||||||
const id = headings[3].getAttribute('id');
|
const id = headings[3].getAttribute('id');
|
||||||
const tocItem = lastTocList[3];
|
const tocItem = lastTocList[3];
|
||||||
expect(id).toEqual('h2-three', 'heading id');
|
expect(id).withContext('heading id').toEqual('h2-three');
|
||||||
expect(tocItem.href).toEqual(`${docId}#h2-three`, 'tocItem href');
|
expect(tocItem.href).withContext('tocItem href').toEqual(`${docId}#h2-three`);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should avoid repeating an id when calculating', () => {
|
it('should avoid repeating an id when calculating', () => {
|
||||||
const tocItems = lastTocList.filter(item => item.title === 'H2 4 repeat');
|
const tocItems = lastTocList.filter(item => item.title === 'H2 4 repeat');
|
||||||
expect(tocItems[0].href).toEqual(`${docId}#h2-4-repeat`, 'first');
|
expect(tocItems[0].href).withContext('first').toEqual(`${docId}#h2-4-repeat`);
|
||||||
expect(tocItems[1].href).toEqual(`${docId}#h2-4-repeat-2`, 'second');
|
expect(tocItems[1].href).withContext('second').toEqual(`${docId}#h2-4-repeat-2`);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,9 @@ describe('PWA manifest', () => {
|
||||||
|
|
||||||
it('should exist', async () => {
|
it('should exist', async () => {
|
||||||
for (const {short_name, url} of shortcuts) {
|
for (const {short_name, url} of shortcuts) {
|
||||||
|
// In Jasmine, passing an `expectationFailOutput` to the `toBe()` method is deprecated in
|
||||||
|
// favor of using the `.withContext()` matcher. However, JasmineWD does not support that.
|
||||||
|
// tslint:disable-next-line: deprecation
|
||||||
expect(await pageExists(url)).toBe(
|
expect(await pageExists(url)).toBe(
|
||||||
true,
|
true,
|
||||||
`Page for shortcut '${short_name}' (from '${page.pwaManifestUrl}') does not exist. (URL: ${url})`);
|
`Page for shortcut '${short_name}' (from '${page.pwaManifestUrl}') does not exist. (URL: ${url})`);
|
||||||
|
|
|
@ -9,7 +9,7 @@ export type Json = null | boolean | number | string | Json[] | { [key: string]:
|
||||||
/**
|
/**
|
||||||
* The shape of a PWA manifest.
|
* The shape of a PWA manifest.
|
||||||
* For simplicity, we only define types for the properties we care about in tests.
|
* For simplicity, we only define types for the properties we care about in tests.
|
||||||
* @see https://developer.mozilla.org/en-US/docs/Web/Manifest
|
* See https://developer.mozilla.org/en-US/docs/Web/Manifest.
|
||||||
*/
|
*/
|
||||||
export type PwaManifest = Json & {
|
export type PwaManifest = Json & {
|
||||||
shortcuts?: PwaShortcutItem[],
|
shortcuts?: PwaShortcutItem[],
|
||||||
|
@ -17,7 +17,7 @@ export type PwaManifest = Json & {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The shape of an item in a PWA manifest's `shortcuts` list.
|
* The shape of an item in a PWA manifest's `shortcuts` list.
|
||||||
* @see https://developer.mozilla.org/en-US/docs/Web/Manifest/shortcuts
|
* See https://developer.mozilla.org/en-US/docs/Web/Manifest/shortcuts.
|
||||||
*/
|
*/
|
||||||
export type PwaShortcutItem = Json & {
|
export type PwaShortcutItem = Json & {
|
||||||
url: string,
|
url: string,
|
||||||
|
@ -30,7 +30,7 @@ export type PwaShortcutItem = Json & {
|
||||||
/**
|
/**
|
||||||
* The shape of an item in a PWA manifest's icons list (such as the value of the top-level `icons` property or that of
|
* The shape of an item in a PWA manifest's icons list (such as the value of the top-level `icons` property or that of
|
||||||
* the `icons` property of a shortcut item).
|
* the `icons` property of a shortcut item).
|
||||||
* @see https://w3c.github.io/manifest/#manifestimageresource-and-its-members
|
* See https://w3c.github.io/manifest/#manifestimageresource-and-its-members.
|
||||||
*/
|
*/
|
||||||
export type PwaImageResource = Json & {
|
export type PwaImageResource = Json & {
|
||||||
src: string,
|
src: string,
|
||||||
|
|
Loading…
Reference in New Issue