Skip to content

Commit

Permalink
fix: check port when devServer is enabled (#10)
Browse files Browse the repository at this point in the history
  • Loading branch information
popomore committed Mar 31, 2018
1 parent 5397894 commit f58d766
Show file tree
Hide file tree
Showing 13 changed files with 89 additions and 3 deletions.
4 changes: 4 additions & 0 deletions agent.js
@@ -1,9 +1,13 @@
'use strict';

const assert = require('assert');
const DevServer = require('./lib/dev_server');

module.exports = agent => {
if (!agent.config.assets.isLocal) return;
if (!agent.config.assets.devServer.enable) return;

assert(agent.config.assets.devServer.port, 'devServer.port is required when devServer is enabled');

const server = new DevServer(agent);
server.ready(err => {
Expand Down
3 changes: 2 additions & 1 deletion app.js
Expand Up @@ -7,7 +7,8 @@ const AssetsView = require('./lib/assets_view');

module.exports = app => {
const assetsConfig = app.config.assets;
if (assetsConfig.isLocal && !assetsConfig.url && assetsConfig.devServer.port) {

if (assetsConfig.devServer.enable && assetsConfig.isLocal) {
assetsConfig.url = 'http://127.0.0.1:' + assetsConfig.devServer.port;
}

Expand Down
1 change: 1 addition & 0 deletions config/config.default.js
Expand Up @@ -25,6 +25,7 @@ module.exports = appInfo => ({
templateViewEngine: '',
contextKey: 'context',
devServer: {
enable: true,
command: '',
port: null,
env: {},
Expand Down
4 changes: 2 additions & 2 deletions test/assets.test.js
Expand Up @@ -200,7 +200,7 @@ describe('test/assets.test.js', () => {
let app;

before(() => {
mock.env('local');
mock.env('prod');
app = mock.cluster({
baseDir: 'apps/custom-assets-url',
});
Expand All @@ -211,7 +211,7 @@ describe('test/assets.test.js', () => {
it('should GET /', () => {
return app.httpRequest()
.get('/')
.expect(/<link rel="stylesheet" href="http:\/\/localhost\/index.css"><\/link>/)
.expect(/<link rel="stylesheet" href="http:\/\/localhost\/index.b8e2efea.css"><\/link>/)
.expect(200);
});
});
Expand Down
25 changes: 25 additions & 0 deletions test/dev_server.test.js
Expand Up @@ -136,4 +136,29 @@ describe('test/dev_server.test.js', () => {
app.expect('stderr', /spawn unknown ENOENT/);
app.expect('stderr', /Run "unknown command" failed after 5s/);
});

it('should check port when devServer is enabled', async () => {
mock.env('local');
app = mock.cluster({
baseDir: 'apps/dev-server-no-port',
});
// app.debug();
await app.ready();

app.expect('code', 1);
app.expect('stderr', /devServer.port is required when devServer is enabled/);
});

it('should not check port when devServer is disabled', async () => {
mock.env('local');
mock(process.env, 'DEV_SERVER_ENABLE', 'false');
app = mock.cluster({
baseDir: 'apps/dev-server-no-port',
});
app.debug();
await app.ready();

app.expect('code', 0);
app.expect('stdout', /egg started/);
});
});
Expand Up @@ -7,4 +7,7 @@ exports.view = {
},
};
exports.assets = {
devServer: {
enable: false,
},
};
11 changes: 11 additions & 0 deletions test/fixtures/apps/dev-server-no-port/app/controller/home.js
@@ -0,0 +1,11 @@
'use strict';

const Controller = require('egg').Controller;

class HomeController extends Controller {
async index() {
await this.ctx.render('index.js');
}
}

module.exports = HomeController;
7 changes: 7 additions & 0 deletions test/fixtures/apps/dev-server-no-port/app/router.js
@@ -0,0 +1,7 @@
'use strict';

module.exports = app => {
const { router, controller } = app;

router.get('/', controller.home.index);
};
Empty file.
21 changes: 21 additions & 0 deletions test/fixtures/apps/dev-server-no-port/config/config.default.js
@@ -0,0 +1,21 @@
'use strict';

exports.keys = '123456';
exports.view = {
mapping: {
'.js': 'assets',
},
};
exports.assets = {
devServer: {
enable: process.env.DEV_SERVER_ENABLE !== 'false',
waitStart: true,
command: 'node ' + require.resolve('./server.js'),
cwd: __dirname,
env: {
DEBUG: true,
},
timeout: 5000,
debug: process.env.DEV_SERVER_DEBUG === 'true',
},
};
10 changes: 10 additions & 0 deletions test/fixtures/apps/dev-server-no-port/config/server.js
@@ -0,0 +1,10 @@
#!/usr/bin/env node

'use strict';

console.log('[server] cwd:', process.cwd());
console.log('[server] DEBUG:', process.env.DEBUG);

if (process.env.EXIT) {
process.exit(1);
}
3 changes: 3 additions & 0 deletions test/fixtures/apps/dev-server-no-port/package.json
@@ -0,0 +1,3 @@
{
"name": "egg-view-assets"
}

0 comments on commit f58d766

Please sign in to comment.