Skip to content

Commit

Permalink
test: add live-reload test
Browse files Browse the repository at this point in the history
  • Loading branch information
filipesilva committed Feb 17, 2017
1 parent fbcf453 commit bc39735
Show file tree
Hide file tree
Showing 2 changed files with 132 additions and 15 deletions.
29 changes: 14 additions & 15 deletions packages/@angular/cli/commands/serve.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import { ServeTaskOptions } from './serve';
const SilentError = require('silent-error');
const PortFinder = require('portfinder');
const Command = require('../ember-cli/lib/models/command');
const getPort = denodeify<{host: string, port: number}, number>(PortFinder.getPort);
const getPort = denodeify<{ host: string, port: number }, number>(PortFinder.getPort);

const config = CliConfig.fromProject() || CliConfig.fromGlobal();
const defaultPort = process.env.PORT || config.get('defaults.serve.port');
Expand Down Expand Up @@ -48,6 +48,18 @@ export const baseServeCommandOptions: any = baseBuildCommandOptions.concat([
default: false,
aliases: ['o'],
description: 'Opens the url in default browser',
},
{ name: 'live-reload', type: Boolean, default: true, aliases: ['lr'] },
{
name: 'live-reload-client',
type: String,
description: 'specify the URL that the live reload browser client will use'
},
{
name: 'hmr',
type: Boolean,
default: false,
description: 'Enable hot module replacement',
}
]);

Expand All @@ -56,20 +68,7 @@ const ServeCommand = Command.extend({
description: 'Builds and serves your app, rebuilding on file changes.',
aliases: ['server', 's'],

availableOptions: baseServeCommandOptions.concat([
{ name: 'live-reload', type: Boolean, default: true, aliases: ['lr'] },
{
name: 'live-reload-client',
type: String,
description: 'specify the URL that the live reload browser client will use'
},
{
name: 'hmr',
type: Boolean,
default: false,
description: 'Enable hot module replacement',
}
]),
availableOptions: baseServeCommandOptions,

run: function (commandOptions: ServeTaskOptions) {
const ServeTask = require('../tasks/serve').default;
Expand Down
118 changes: 118 additions & 0 deletions tests/e2e/tests/misc/live-reload.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,118 @@
import * as express from 'express';
import * as http from 'http';

import { appendToFile, writeMultipleFiles } from '../../utils/fs';
import {
killAllProcesses,
silentExecAndWaitForOutputToMatch,
waitForAnyProcessOutputToMatch
} from '../../utils/process';
import { wait } from '../../utils/utils';


export default function () {
const protractorGoodRegEx = /Spec started/;
const webpackGoodRegEx = /webpack: Compiled successfully./;

// Create an express api for the Angular app to call.
const app = express();
const server = http.createServer(app);
let liveReloadCount = 0;
let liveReloadClientCalled = false;
function resetApiVars() {
liveReloadCount = 0;
liveReloadClientCalled = false;
}

server.listen(0);
app.set('port', server.address().port);
const apiUrl = `http://localhost:${server.address().port}`;

// This endpoint will be pinged by the main app on each reload.
app.get('/live-reload-count', _ => liveReloadCount++);
// This endpoint will be pinged by webpack to check for live reloads.
app.get('/sockjs-node/info', _ => liveReloadClientCalled = true);


return Promise.resolve()
.then(_ => writeMultipleFiles({
// e2e test that just opens the page and waits, so that the app runs.
'./e2e/app.e2e-spec.ts': `
import { browser } from 'protractor';
describe('master-project App', function() {
it('should wait', _ => {
browser.get('/');
browser.sleep(30000);
});
});
`,
// App that calls the express server once.
'./src/app/app.component.ts': `
import { Component } from '@angular/core';
import { Http } from '@angular/http';
@Component({
selector: 'app-root',
template: '<h1>Live reload test</h1>'
})
export class AppComponent {
constructor(private http: Http) {
http.get('${apiUrl + '/live-reload-count'}').subscribe(res => null);
}
}
`
}))
.then(_ => silentExecAndWaitForOutputToMatch(
'ng',
['e2e', '--watch', '--live-reload'],
protractorGoodRegEx
))
// Let app run.
.then(_ => wait(1000))
.then(_ => appendToFile('src/main.ts', 'console.log(1);'))
.then(_ => waitForAnyProcessOutputToMatch(webpackGoodRegEx, 5000))
.then(_ => wait(1000))
.then(_ => {
if (liveReloadCount != 2) {
throw new Error(
`Expected API to have been called 2 times but it was called ${liveReloadCount} times.`
);
}
})
.then(_ => killAllProcesses(), (err) => { killAllProcesses(); throw err; })
.then(_ => resetApiVars())
// Serve with live reload off should call api only once.
.then(_ => silentExecAndWaitForOutputToMatch(
'ng',
['e2e', '--watch', '--no-live-reload'],
protractorGoodRegEx
))
.then(_ => wait(1000))
.then(_ => appendToFile('src/main.ts', 'console.log(1);'))
.then(_ => waitForAnyProcessOutputToMatch(webpackGoodRegEx, 5000))
.then(_ => wait(1000))
.then(_ => {
if (liveReloadCount != 1) {
throw new Error(
`Expected API to have been called 1 time but it was called ${liveReloadCount} times.`
);
}
})
.then(_ => killAllProcesses(), (err) => { killAllProcesses(); throw err; })
.then(_ => resetApiVars())
// Serve with live reload client set to api should call api.
.then(_ => silentExecAndWaitForOutputToMatch(
'ng',
['e2e', '--watch', `--live-reload-client=${apiUrl}`],
protractorGoodRegEx
))
.then(_ => wait(2000))
.then(_ => {
if (!liveReloadClientCalled) {
throw new Error(`Expected live-reload client to have been called but it was not.`);
}
})
.then(_ => killAllProcesses(), (err) => { killAllProcesses(); throw err; })
.then(_ => server.close(), (err) => { server.close(); throw err; });
}

0 comments on commit bc39735

Please sign in to comment.