Merge pull request #2 from strongloop/feature/support-custom-api-path

Support custom basePath
This commit is contained in:
Miroslav Bajtoš 2013-11-29 08:41:03 -08:00
commit f563a608e8
4 changed files with 166 additions and 104 deletions

View File

@ -4,6 +4,7 @@
var path = require('path'); var path = require('path');
var loopback = require('loopback'); var loopback = require('loopback');
var swagger = require('loopback/node_modules/strong-remoting/ext/swagger'); var swagger = require('loopback/node_modules/strong-remoting/ext/swagger');
var express = require('loopback/node_modules/express');
var STATIC_ROOT = path.join(__dirname, 'public'); var STATIC_ROOT = path.join(__dirname, 'public');
module.exports = explorer; module.exports = explorer;
@ -16,7 +17,16 @@ module.exports = explorer;
*/ */
function explorer(loopbackApplication, options) { function explorer(loopbackApplication, options) {
var options = options || {};
var remotes = loopbackApplication.remotes(); var remotes = loopbackApplication.remotes();
swagger(remotes, options); swagger(remotes, options);
return loopback.static(STATIC_ROOT);
var app = express();
app.get('/config.json', function(req, res) {
res.send({
discoveryUrl: (options.basePath || '') + '/swagger/resources'
});
});
app.use(loopback.static(STATIC_ROOT));
return app;
} }

View File

@ -28,6 +28,7 @@
"devDependencies": { "devDependencies": {
"loopback": "1.x.x", "loopback": "1.x.x",
"mocha": "~1.14.0", "mocha": "~1.14.0",
"supertest": "~0.8.1" "supertest": "~0.8.1",
"chai": "~1.8.1"
} }
} }

View File

@ -17,15 +17,22 @@
<script src='lib/highlight.7.3.pack.js' type='text/javascript'></script> <script src='lib/highlight.7.3.pack.js' type='text/javascript'></script>
<script type="text/javascript"> <script type="text/javascript">
$(function () { $(function() {
$.getJSON('config.json', function(config) {
console.log(config);
loadSwaggerUi(config);
});
});
function loadSwaggerUi(config) {
window.swaggerUi = new SwaggerUi({ window.swaggerUi = new SwaggerUi({
discoveryUrl:"/swagger/resources", discoveryUrl: config.discoveryUrl || "/swagger/resources",
apiKey:"", apiKey: "",
dom_id:"swagger-ui-container", dom_id: "swagger-ui-container",
supportHeaderParams: true, supportHeaderParams: true,
supportedSubmitMethods: ['get', 'post', 'put', 'delete'], supportedSubmitMethods: ['get', 'post', 'put', 'delete'],
onComplete: function(swaggerApi, swaggerUi){ onComplete: function(swaggerApi, swaggerUi) {
if(console) { if (console) {
console.log("Loaded SwaggerUI") console.log("Loaded SwaggerUI")
console.log(swaggerApi); console.log(swaggerApi);
console.log(swaggerUi); console.log(swaggerUi);
@ -33,7 +40,7 @@
$('pre code').each(function(i, e) {hljs.highlightBlock(e)}); $('pre code').each(function(i, e) {hljs.highlightBlock(e)});
}, },
onFailure: function(data) { onFailure: function(data) {
if(console) { if (console) {
console.log("Unable to Load SwaggerUI"); console.log("Unable to Load SwaggerUI");
console.log(data); console.log(data);
} }
@ -42,8 +49,7 @@
}); });
window.swaggerUi.load(); window.swaggerUi.load();
}); }
</script> </script>
</head> </head>
@ -53,8 +59,11 @@
<a id="logo">StrongLoop API Explorer</a> <a id="logo">StrongLoop API Explorer</a>
<form id='api_selector'> <form id='api_selector'>
<div class='input'><input placeholder="http://example.com/api" id="input_baseUrl" name="baseUrl" <div class='input'>
type="text"/></div> <input placeholder="http://example.com/api"
id="input_baseUrl" name="baseUrl"
type="text"/>
</div>
<div class='input'><a id="explore" href="#">Explore</a></div> <div class='input'><a id="explore" href="#">Explore</a></div>
</form> </form>
</div> </div>

View File

@ -1,38 +1,80 @@
var loopback = require('loopback');
var explorer = require('../');
var request = require('supertest'); var request = require('supertest');
var assert = require('assert'); var assert = require('assert');
var expect = require('chai').expect;
describe('explorer', function () { describe('explorer', function() {
beforeEach(function (done) {
var loopback = require('loopback');
var app = this.app = loopback();
var explorer = require('../');
var Product = loopback.Model.extend('product');
Product.attachTo(loopback.memory());
app.model(Product);
app.use(loopback.rest()); describe('with default config', function() {
app.use('/explorer', explorer(app)); beforeEach(givenLoopBackAppWithExplorer());
done(); it('should redirect to /explorer/', function(done) {
});
it('should redirect to /explorer/', function (done) {
request(this.app) request(this.app)
.get('/explorer') .get('/explorer')
.expect(303) .expect(303)
.end(done); .end(done);
}); });
it('should serve the explorer at /explorer/', function (done) { it('should serve the explorer at /explorer/', function(done) {
request(this.app) request(this.app)
.get('/explorer/') .get('/explorer/')
.expect('Content-Type', /html/) .expect('Content-Type', /html/)
.expect(200) .expect(200)
.end(function(err, res) { .end(function(err, res) {
if(err) throw err; if (err) throw err;
assert(!!~res.text.indexOf('<title>StrongLoop API Explorer</title>'), 'text does not contain expected string'); assert(!!~res.text.indexOf('<title>StrongLoop API Explorer</title>'), 'text does not contain expected string');
done(); done();
}); });
}); });
it('should serve correct swagger-ui config', function(done) {
request(this.app)
.get('/explorer/config.json')
.expect('Content-Type', /json/)
.expect(200)
.end(function(err, res) {
if (err) return done(err);
expect(res.body).to
.have.property('discoveryUrl', '/swagger/resources');
done();
});
});
})
describe('with custom baseUrl', function() {
beforeEach(givenLoopBackAppWithExplorer('/api'));
it('should serve correct swagger-ui config', function(done) {
request(this.app)
.get('/explorer/config.json')
.expect('Content-Type', /json/)
.expect(200)
.end(function(err, res) {
if (err) return done(err);
expect(res.body).to
.have.property('discoveryUrl', '/api/swagger/resources');
done();
});
});
});
function givenLoopBackAppWithExplorer(restUrlBase) {
return function(done) {
var app = this.app = loopback();
var Product = loopback.Model.extend('product');
Product.attachTo(loopback.memory());
app.model(Product);
if (restUrlBase) {
app.use(restUrlBase, loopback.rest());
app.use('/explorer', explorer(app, { basePath: restUrlBase }));
} else {
app.use(loopback.rest());
app.use('/explorer', explorer(app));
}
done();
}
}
}); });