fix and test some edge cases in router
This commit is contained in:
parent
8bc3c2b4d4
commit
c2acdf6f4a
2 changed files with 158 additions and 13 deletions
|
|
@ -8,11 +8,11 @@ module.exports = function($window, redrawService) {
|
||||||
var routeService = coreRouter($window)
|
var routeService = coreRouter($window)
|
||||||
|
|
||||||
var identity = function(v) {return v}
|
var identity = function(v) {return v}
|
||||||
var render, component, attrs, currentPath
|
var routing = false, render, component, attrs, currentPath, resolve
|
||||||
var route = function(root, defaultRoute, routes) {
|
var route = function(root, defaultRoute, routes) {
|
||||||
if (root == null) throw new Error("Ensure the DOM element that was passed to `m.route` is not undefined")
|
if (root == null) throw new Error("Ensure the DOM element that was passed to `m.route` is not undefined")
|
||||||
var update = function(routeResolver, comp, params, path) {
|
var update = function(routeResolver, comp, params, path) {
|
||||||
component = comp || "div", attrs = params, currentPath = path
|
component = comp || "div", attrs = params, currentPath = path, resolve = null
|
||||||
render = (routeResolver.render || identity).bind(routeResolver)
|
render = (routeResolver.render || identity).bind(routeResolver)
|
||||||
run()
|
run()
|
||||||
}
|
}
|
||||||
|
|
@ -23,10 +23,16 @@ module.exports = function($window, redrawService) {
|
||||||
if (payload.view) update({}, payload, params, path)
|
if (payload.view) update({}, payload, params, path)
|
||||||
else {
|
else {
|
||||||
if (payload.onmatch) {
|
if (payload.onmatch) {
|
||||||
Promise.resolve(payload.onmatch(params, path)).then(function(resolved) {
|
if (resolve != null) update(payload, component, params, path)
|
||||||
|
else {
|
||||||
|
resolve = function(resolved) {
|
||||||
update(payload, resolved, params, path)
|
update(payload, resolved, params, path)
|
||||||
|
}
|
||||||
|
Promise.resolve(payload.onmatch(params, path)).then(function(resolved) {
|
||||||
|
if (resolve != null) resolve(resolved)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else update(payload, "div", params, path)
|
else update(payload, "div", params, path)
|
||||||
}
|
}
|
||||||
}, function() {
|
}, function() {
|
||||||
|
|
@ -34,7 +40,10 @@ module.exports = function($window, redrawService) {
|
||||||
})
|
})
|
||||||
redrawService.subscribe(root, run)
|
redrawService.subscribe(root, run)
|
||||||
}
|
}
|
||||||
route.set = routeService.setPath
|
route.set = function(path, data, options) {
|
||||||
|
resolve = null
|
||||||
|
routeService.setPath(path, data, options)
|
||||||
|
}
|
||||||
route.get = function() {return currentPath}
|
route.get = function() {return currentPath}
|
||||||
route.prefix = routeService.setPrefix
|
route.prefix = routeService.setPrefix
|
||||||
route.link = routeService.link
|
route.link = routeService.link
|
||||||
|
|
|
||||||
|
|
@ -456,13 +456,15 @@ o.spec("route", function() {
|
||||||
|
|
||||||
o("onmatch can redirect to another route", function(done) {
|
o("onmatch can redirect to another route", function(done) {
|
||||||
var redirected = false
|
var redirected = false
|
||||||
|
var render = o.spy()
|
||||||
|
|
||||||
$window.location.href = prefix + "/a"
|
$window.location.href = prefix + "/a"
|
||||||
route(root, "/a", {
|
route(root, "/a", {
|
||||||
"/a" : {
|
"/a" : {
|
||||||
onmatch: function() {
|
onmatch: function() {
|
||||||
route.set("/b")
|
route.set("/b")
|
||||||
}
|
},
|
||||||
|
render: render
|
||||||
},
|
},
|
||||||
"/b" : {
|
"/b" : {
|
||||||
view: function(vnode){
|
view: function(vnode){
|
||||||
|
|
@ -472,6 +474,7 @@ o.spec("route", function() {
|
||||||
})
|
})
|
||||||
|
|
||||||
callAsync(function() {
|
callAsync(function() {
|
||||||
|
o(render.callCount).equals(0)
|
||||||
o(redirected).equals(true)
|
o(redirected).equals(true)
|
||||||
|
|
||||||
done()
|
done()
|
||||||
|
|
@ -480,13 +483,15 @@ o.spec("route", function() {
|
||||||
|
|
||||||
o("onmatch can redirect to another route that has RouteResolver w/ only onmatch", function(done) {
|
o("onmatch can redirect to another route that has RouteResolver w/ only onmatch", function(done) {
|
||||||
var redirected = false
|
var redirected = false
|
||||||
|
var render = o.spy()
|
||||||
|
|
||||||
$window.location.href = prefix + "/a"
|
$window.location.href = prefix + "/a"
|
||||||
route(root, "/a", {
|
route(root, "/a", {
|
||||||
"/a" : {
|
"/a" : {
|
||||||
onmatch: function() {
|
onmatch: function() {
|
||||||
route.set("/b")
|
route.set("/b")
|
||||||
}
|
},
|
||||||
|
render: render
|
||||||
},
|
},
|
||||||
"/b" : {
|
"/b" : {
|
||||||
onmatch: function() {
|
onmatch: function() {
|
||||||
|
|
@ -497,6 +502,7 @@ o.spec("route", function() {
|
||||||
})
|
})
|
||||||
|
|
||||||
callAsync(function() {
|
callAsync(function() {
|
||||||
|
o(render.callCount).equals(0)
|
||||||
o(redirected).equals(true)
|
o(redirected).equals(true)
|
||||||
|
|
||||||
done()
|
done()
|
||||||
|
|
@ -505,13 +511,15 @@ o.spec("route", function() {
|
||||||
|
|
||||||
o("onmatch can redirect to another route that has RouteResolver w/ only render", function(done) {
|
o("onmatch can redirect to another route that has RouteResolver w/ only render", function(done) {
|
||||||
var redirected = false
|
var redirected = false
|
||||||
|
var render = o.spy()
|
||||||
|
|
||||||
$window.location.href = prefix + "/a"
|
$window.location.href = prefix + "/a"
|
||||||
route(root, "/a", {
|
route(root, "/a", {
|
||||||
"/a" : {
|
"/a" : {
|
||||||
onmatch: function() {
|
onmatch: function() {
|
||||||
route.set("/b")
|
route.set("/b")
|
||||||
}
|
},
|
||||||
|
render: render
|
||||||
},
|
},
|
||||||
"/b" : {
|
"/b" : {
|
||||||
render: function(vnode){
|
render: function(vnode){
|
||||||
|
|
@ -521,12 +529,101 @@ o.spec("route", function() {
|
||||||
})
|
})
|
||||||
|
|
||||||
callAsync(function() {
|
callAsync(function() {
|
||||||
|
o(render.callCount).equals(0)
|
||||||
o(redirected).equals(true)
|
o(redirected).equals(true)
|
||||||
|
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
o("onmatch can redirect to a non-existent route that defaults to a RouteResolver w/ onmatch", function(done) {
|
||||||
|
var redirected = false
|
||||||
|
var render = o.spy()
|
||||||
|
|
||||||
|
$window.location.href = prefix + "/a"
|
||||||
|
route(root, "/b", {
|
||||||
|
"/a" : {
|
||||||
|
onmatch: function() {
|
||||||
|
route.set("/c")
|
||||||
|
},
|
||||||
|
render: render
|
||||||
|
},
|
||||||
|
"/b" : {
|
||||||
|
onmatch: function(vnode){
|
||||||
|
redirected = true
|
||||||
|
return {view: function() {}}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
callAsync(function() {
|
||||||
|
callAsync(function() {
|
||||||
|
o(render.callCount).equals(0)
|
||||||
|
o(redirected).equals(true)
|
||||||
|
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
o("onmatch can redirect to a non-existent route that defaults to a RouteResolver w/ render", function(done) {
|
||||||
|
var redirected = false
|
||||||
|
var render = o.spy()
|
||||||
|
|
||||||
|
$window.location.href = prefix + "/a"
|
||||||
|
route(root, "/b", {
|
||||||
|
"/a" : {
|
||||||
|
onmatch: function() {
|
||||||
|
route.set("/c")
|
||||||
|
},
|
||||||
|
render: render
|
||||||
|
},
|
||||||
|
"/b" : {
|
||||||
|
render: function(vnode){
|
||||||
|
redirected = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
callAsync(function() {
|
||||||
|
callAsync(function() {
|
||||||
|
o(render.callCount).equals(0)
|
||||||
|
o(redirected).equals(true)
|
||||||
|
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
o("onmatch can redirect to a non-existent route that defaults to a component", function(done) {
|
||||||
|
var redirected = false
|
||||||
|
var render = o.spy()
|
||||||
|
|
||||||
|
$window.location.href = prefix + "/a"
|
||||||
|
route(root, "/b", {
|
||||||
|
"/a" : {
|
||||||
|
onmatch: function() {
|
||||||
|
route.set("/c")
|
||||||
|
},
|
||||||
|
render: render
|
||||||
|
},
|
||||||
|
"/b" : {
|
||||||
|
view: function(vnode){
|
||||||
|
redirected = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
callAsync(function() {
|
||||||
|
callAsync(function() {
|
||||||
|
o(render.callCount).equals(0)
|
||||||
|
o(redirected).equals(true)
|
||||||
|
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
o("the previous view redraws while onmatch resolution is pending (#1268)", function(done) {
|
o("the previous view redraws while onmatch resolution is pending (#1268)", function(done) {
|
||||||
var view = o.spy()
|
var view = o.spy()
|
||||||
var onmatch = o.spy(function() {
|
var onmatch = o.spy(function() {
|
||||||
|
|
@ -609,9 +706,7 @@ o.spec("route", function() {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
o("routing with RouteResolver works more than once", function(done, timeout) {
|
o("routing with RouteResolver works more than once", function(done) {
|
||||||
timeout(200)
|
|
||||||
|
|
||||||
$window.location.href = prefix + "/a"
|
$window.location.href = prefix + "/a"
|
||||||
route(root, '/a', {
|
route(root, '/a', {
|
||||||
'/a': {
|
'/a': {
|
||||||
|
|
@ -676,6 +771,47 @@ o.spec("route", function() {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
o("calling route.set invalidates pending onmatch resolution", function(done) {
|
||||||
|
var rendered = false
|
||||||
|
var resolved
|
||||||
|
$window.location.href = prefix + "/a"
|
||||||
|
route(root, "/a", {
|
||||||
|
"/a": {
|
||||||
|
onmatch: function() {
|
||||||
|
return new Promise(function(resolve) {
|
||||||
|
callAsync(function() {
|
||||||
|
callAsync(function() {
|
||||||
|
resolve({view: function() {rendered = true}})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
},
|
||||||
|
render: function(vnode) {
|
||||||
|
rendered = true
|
||||||
|
resolved = "a"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"/b": {
|
||||||
|
view: function() {
|
||||||
|
resolved = "b"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
route.set("/b")
|
||||||
|
|
||||||
|
callAsync(function() {
|
||||||
|
o(rendered).equals(false)
|
||||||
|
o(resolved).equals("b")
|
||||||
|
|
||||||
|
callAsync(function() {
|
||||||
|
o(rendered).equals(false)
|
||||||
|
o(resolved).equals("b")
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
o("route changes activate onbeforeremove", function(done) {
|
o("route changes activate onbeforeremove", function(done) {
|
||||||
var spy = o.spy()
|
var spy = o.spy()
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue