describe("path-deps extension", function() {
beforeEach(function () {
this.server = makeServer();
clearWorkArea();
});
afterEach(function () {
this.server.restore();
clearWorkArea();
});
it('path-deps basic case works', function () {
this.server.respondWith("POST", "/test", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var btn = make('')
var div = make('
FOO
')
btn.click();
this.server.respond();
btn.innerHTML.should.equal("Clicked!");
div.innerHTML.should.equal("FOO");
this.server.respond();
div.innerHTML.should.equal("Deps fired!");
});
it('path-deps works with trailing slash', function () {
this.server.respondWith("POST", "/test", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var btn = make('')
var div = make('
FOO
')
btn.click();
this.server.respond();
btn.innerHTML.should.equal("Clicked!");
div.innerHTML.should.equal("FOO");
this.server.respond();
div.innerHTML.should.equal("Deps fired!");
});
it('path-deps GET does not trigger', function () {
this.server.respondWith("GET", "/test", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var btn = make('')
var div = make('
FOO
')
btn.click();
this.server.respond();
btn.innerHTML.should.equal("Clicked!");
div.innerHTML.should.equal("FOO");
this.server.respond();
div.innerHTML.should.equal("FOO");
});
it('path-deps dont trigger on path mismatch', function () {
this.server.respondWith("POST", "/test", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var btn = make('')
var div = make('
FOO
')
btn.click();
this.server.respond();
btn.innerHTML.should.equal("Clicked!");
div.innerHTML.should.equal("FOO");
this.server.respond();
div.innerHTML.should.equal("FOO");
});
it('path-deps dont trigger on path longer than request', function () {
this.server.respondWith("POST", "/test", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var btn = make('')
var div = make('
FOO
')
btn.click();
this.server.respond();
btn.innerHTML.should.equal("Clicked!");
div.innerHTML.should.equal("FOO");
this.server.respond();
div.innerHTML.should.equal("FOO");
});
it('path-deps trigger on path shorter than request', function () {
this.server.respondWith("POST", "/test/child", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var btn = make('')
var div = make('
FOO
')
btn.click();
this.server.respond();
btn.innerHTML.should.equal("Clicked!");
div.innerHTML.should.equal("FOO");
this.server.respond();
div.innerHTML.should.equal("Deps fired!");
});
it('path-deps trigger on *-at-start path', function () {
this.server.respondWith("POST", "/test/child/test", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var btn = make('')
var div = make('
FOO
')
btn.click();
this.server.respond();
btn.innerHTML.should.equal("Clicked!");
div.innerHTML.should.equal("FOO");
this.server.respond();
div.innerHTML.should.equal("Deps fired!");
});
it('path-deps trigger on *-in-middle path', function () {
this.server.respondWith("POST", "/test/child/test", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var btn = make('')
var div = make('
FOO
')
btn.click();
this.server.respond();
btn.innerHTML.should.equal("Clicked!");
div.innerHTML.should.equal("FOO");
this.server.respond();
div.innerHTML.should.equal("Deps fired!");
});
it('path-deps trigger on *-at-end path', function () {
this.server.respondWith("POST", "/test/child/test", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var btn = make('')
var div = make('
FOO
')
btn.click();
this.server.respond();
btn.innerHTML.should.equal("Clicked!");
div.innerHTML.should.equal("FOO");
this.server.respond();
div.innerHTML.should.equal("Deps fired!");
});
it('path-deps trigger all *s path', function () {
this.server.respondWith("POST", "/test/child/test", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var btn = make('')
var div = make('
FOO
')
btn.click();
this.server.respond();
btn.innerHTML.should.equal("Clicked!");
div.innerHTML.should.equal("FOO");
this.server.respond();
div.innerHTML.should.equal("Deps fired!");
});
it('path-deps api basic refresh case works', function () {
this.server.respondWith("GET", "/test", "Path deps fired!");
var div = make('
FOO
')
PathDeps.refresh("/test");
this.server.respond();
div.innerHTML.should.equal("Path deps fired!");
});
it('path-deps api parent path case works', function () {
this.server.respondWith("GET", "/test1", "Path deps 1 fired!");
this.server.respondWith("GET", "/test2", "Path deps 2 fired!");
var div = make('
FOO
')
var div2 = make('
BAR
')
PathDeps.refresh("/test/child");
this.server.respond();
div.innerHTML.should.equal("Path deps 1 fired!");
this.server.respond();
div2.innerHTML.should.equal("Path deps 2 fired!");
});
it('path-deps replacing containing element fires event', function () {
this.server.respondWith("POST", "/test", "Clicked!");
this.server.respondWith("GET", "/test2", "Deps fired!");
var div1 = make('')
var div2 = make('