import { browser, element, by } from 'protractor'; import { logging } from 'selenium-webdriver'; describe('Binding syntax e2e tests', () => { beforeEach(() => browser.get('')); // helper function used to test what's logged to the console async function logChecker(contents: string) { const logs = await browser.manage().logs().get(logging.Type.BROWSER); const messages = logs.filter(({ message }) => message.indexOf(contents) !== -1 ? true : false); expect(messages.length).toBeGreaterThan(0); } it('should display Binding syntax', async () => { expect(await element(by.css('h1')).getText()).toEqual('Binding syntax'); }); it('should display Save button', async () => { expect(await element.all(by.css('button')).get(0).getText()).toBe('Save'); }); it('should display HTML attributes and DOM properties', async () => { expect(await element.all(by.css('h2')).get(1).getText()).toBe('HTML attributes and DOM properties'); }); it('should display 1. Use the inspector...', async () => { expect(await element.all(by.css('p')).get(0).getText()).toContain('1. Use the inspector'); }); it('should display Disabled property vs. attribute', async () => { expect(await element.all(by.css('h3')).get(0).getText()).toBe('Disabled property vs. attribute'); }); it('should log a message including Sarah', async () => { const attributeButton = element.all(by.css('button')).get(1); await attributeButton.click(); const contents = 'Sarah'; await logChecker(contents); }); it('should log a message including Sarah for DOM property', async () => { const DOMPropertyButton = element.all(by.css('button')).get(2); await DOMPropertyButton.click(); const contents = 'Sarah'; await logChecker(contents); }); it('should log a message including Sally for DOM property', async () => { const DOMPropertyButton = element.all(by.css('button')).get(2); const input = element(by.css('input')); await input.sendKeys('Sally'); await DOMPropertyButton.click(); const contents = 'Sally'; await logChecker(contents); }); it('should log a message that Test Button works', async () => { const testButton = element.all(by.css('button')).get(3); await testButton.click(); const contents = 'Test'; await logChecker(contents); }); it('should toggle Test Button disabled', async () => { const toggleButton = element.all(by.css('button')).get(4); await toggleButton.click(); const contents = 'true'; await logChecker(contents); }); });