BUGFIX: clicking on links to the same domain was broken

This commit is contained in:
Régis Hanol 2014-01-29 11:31:36 +01:00
parent ecbcbf0a44
commit d0c55010aa
2 changed files with 35 additions and 10 deletions

View File

@ -54,9 +54,9 @@ Discourse.URL = Em.Object.createWithMixins({
} }
var oldPath = window.location.pathname; var oldPath = window.location.pathname;
path = path.replace(/https?\:\/\/[^\/]+/, ''); path = path.replace(/(https?\:)?\/\/[^\/]+/, '');
// If the URL is absolute, remove rootURL // handle prefixes
if (path.match(/^\//)) { if (path.match(/^\//)) {
var rootURL = (Discourse.BaseUri === undefined ? "/" : Discourse.BaseUri); var rootURL = (Discourse.BaseUri === undefined ? "/" : Discourse.BaseUri);
rootURL = rootURL.replace(/\/$/, ''); rootURL = rootURL.replace(/\/$/, '');
@ -71,11 +71,8 @@ Discourse.URL = Em.Object.createWithMixins({
if (path.match(/^\/?users\/[^\/]+$/)) { if (path.match(/^\/?users\/[^\/]+$/)) {
path += "/activity"; path += "/activity";
} }
// Be wary of looking up the router. In this case, we have links in our
// HTML, say form compiled markdown posts, that need to be routed. return this.handleURL(path);
var router = this.get('router');
router.router.updateURL(path);
return router.handleURL(path);
}, },
/** /**
@ -238,6 +235,21 @@ Discourse.URL = Em.Object.createWithMixins({
**/ **/
controllerFor: function(name) { controllerFor: function(name) {
return Discourse.__container__.lookup('controller:' + name); return Discourse.__container__.lookup('controller:' + name);
},
/**
@private
Be wary of looking up the router. In this case, we have links in our
HTML, say form compiled markdown posts, that need to be routed.
@method handleURL
@param {String} path the url to handle
**/
handleURL: function(path) {
var router = this.get('router');
router.router.updateURL(path);
return router.handleURL(path);
} }
}); });

View File

@ -3,11 +3,11 @@ module("Discourse.URL");
test("isInternal with a HTTP url", function() { test("isInternal with a HTTP url", function() {
this.stub(Discourse.URL, "origin").returns("http://eviltrout.com"); this.stub(Discourse.URL, "origin").returns("http://eviltrout.com");
ok(!Discourse.URL.isInternal(null), "a blank URL is not internal"); not(Discourse.URL.isInternal(null), "a blank URL is not internal");
ok(Discourse.URL.isInternal("/test"), "relative URLs are internal"); ok(Discourse.URL.isInternal("/test"), "relative URLs are internal");
ok(Discourse.URL.isInternal("http://eviltrout.com/tophat"), "a url on the same host is internal"); ok(Discourse.URL.isInternal("http://eviltrout.com/tophat"), "a url on the same host is internal");
ok(Discourse.URL.isInternal("https://eviltrout.com/moustache"), "a url on a HTTPS of the same host is internal"); ok(Discourse.URL.isInternal("https://eviltrout.com/moustache"), "a url on a HTTPS of the same host is internal");
ok(!Discourse.URL.isInternal("http://twitter.com"), "a different host is not internal"); not(Discourse.URL.isInternal("http://twitter.com"), "a different host is not internal");
}); });
test("isInternal with a HTTPS url", function() { test("isInternal with a HTTPS url", function() {
@ -15,6 +15,19 @@ test("isInternal with a HTTPS url", function() {
ok(Discourse.URL.isInternal("http://eviltrout.com/monocle"), "HTTPS urls match HTTP urls"); ok(Discourse.URL.isInternal("http://eviltrout.com/monocle"), "HTTPS urls match HTTP urls");
}); });
// --------------------------------------------
// I DON'T KNOW WHY THIS BREAKS OTHER TESTS :(
// --------------------------------------------
// test("routeTo", function() {
// this.stub(Discourse.URL, "handleURL", function (path) { return path === "/t/topic-title/42"; });
// ok(Discourse.URL.routeTo("https://discourse.org/t/topic-title/42"), "can route HTTPS");
// ok(Discourse.URL.routeTo("http://discourse.org/t/topic-title/42"), "can route HTTP");
// ok(Discourse.URL.routeTo("//discourse.org/t/topic-title/42"), "can route schemaless");
// ok(Discourse.URL.routeTo("/t/topic-title/42"), "can route relative");
// });
test("navigatedToHome", function() { test("navigatedToHome", function() {
var fakeDiscoveryController = { send: function() { return true; } }; var fakeDiscoveryController = { send: function() { return true; } };
var mock = sinon.mock(fakeDiscoveryController); var mock = sinon.mock(fakeDiscoveryController);
@ -26,7 +39,7 @@ test("navigatedToHome", function() {
var homepage = "/" + Discourse.Utilities.defaultHomepage(); var homepage = "/" + Discourse.Utilities.defaultHomepage();
ok(Discourse.URL.navigatedToHome(homepage, "/")); ok(Discourse.URL.navigatedToHome(homepage, "/"));
ok(!Discourse.URL.navigatedToHome("/old", "/new")); not(Discourse.URL.navigatedToHome("/old", "/new"));
// make sure we called the .refresh() method // make sure we called the .refresh() method
mock.verify(); mock.verify();