From 6a2f14c292637d414993583cb94f79d10c3cd48a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Carl=20T=C3=B6rnqvist?= Date: Tue, 2 Apr 2019 09:27:06 +0200 Subject: [PATCH] Fix location missing on store init (#695) --- index.js | 2 +- test.js | 35 +++++++++++++++++++++++++++++------ 2 files changed, 30 insertions(+), 7 deletions(-) diff --git a/index.js b/index.js index 45effedc..48d125a8 100644 --- a/index.js +++ b/index.js @@ -212,11 +212,11 @@ Choo.prototype.toString = function (location, state) { var self = this this._setCache(this.state) + this._matchRoute(location) this._stores.forEach(function (initStore) { initStore(self.state) }) - this._matchRoute(location) var html = this._prerender(this.state) assert.ok(html, 'choo.toString: no valid value returned for the route ' + location) assert(!Array.isArray(html), 'choo.toString: return value was an array for the route ' + location) diff --git a/test.js b/test.js index 22399a8b..859fd7e8 100644 --- a/test.js +++ b/test.js @@ -194,18 +194,41 @@ tape('state should include query', function (t) { t.end() }) -tape('state should include href', function (t) { - t.plan(2) +tape('state should include location on render', function (t) { + t.plan(6) var app = choo() - app.route('/:resource/:id', function (state, emit) { - t.ok(state.hasOwnProperty('href'), 'state has href property') - t.equal(state.href, '/users/1', 'href is users/1') + app.route('/:foo', function (state, emit) { + t.equal(state.href, '/foo', 'state has href') + t.equal(state.route, ':foo', 'state has route') + t.ok(state.hasOwnProperty('params'), 'state has params') + t.deepEqual(state.params, { foo: 'foo' }, 'params match') + t.ok(state.hasOwnProperty('query'), 'state has query') + t.deepEqual(state.query, { bar: 'baz' }, 'query match') return html`
` }) - app.toString('/users/1?page=2') // should ignore query + app.toString('/foo?bar=baz') t.end() }) +tape('state should include location on store init', function (t) { + t.plan(6) + var app = choo() + app.use(store) + app.route('/:foo', function (state, emit) { + return html`
` + }) + app.toString('/foo?bar=baz') + + function store (state, emit) { + t.equal(state.href, '/foo', 'state has href') + t.equal(state.route, ':foo', 'state has route') + t.ok(state.hasOwnProperty('params'), 'state has params') + t.deepEqual(state.params, { foo: 'foo' }, 'params match') + t.ok(state.hasOwnProperty('query'), 'state has query') + t.deepEqual(state.query, { bar: 'baz' }, 'query match') + } +}) + // TODO: Implement this using jsdom, as this only works when window is present tape.skip('state should include title', function (t) {})