summaryrefslogtreecommitdiffstatshomepage
path: root/www/test/0.1.1/test/ext/path-deps.js
diff options
context:
space:
mode:
Diffstat (limited to 'www/test/0.1.1/test/ext/path-deps.js')
-rw-r--r--www/test/0.1.1/test/ext/path-deps.js142
1 files changed, 142 insertions, 0 deletions
diff --git a/www/test/0.1.1/test/ext/path-deps.js b/www/test/0.1.1/test/ext/path-deps.js
new file mode 100644
index 00000000..8dea9f70
--- /dev/null
+++ b/www/test/0.1.1/test/ext/path-deps.js
@@ -0,0 +1,142 @@
+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('<button hx-post="/test" hx-ext="path-deps">Click Me!</button>')
+ var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test">FOO</div>')
+ 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('<button hx-post="/test" hx-ext="path-deps">Click Me!</button>')
+ var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test/">FOO</div>')
+ 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('<button hx-get="/test" hx-ext="path-deps">Click Me!</button>')
+ var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test">FOO</div>')
+ 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('<button hx-post="/test" hx-ext="path-deps">Click Me!</button>')
+ var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test2">FOO</div>')
+ 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('<button hx-post="/test" hx-ext="path-deps">Click Me!</button>')
+ var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test/child">FOO</div>')
+ 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('<button hx-post="/test/child" hx-ext="path-deps">Click Me!</button>')
+ var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test">FOO</div>')
+ 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('<button hx-post="/test/child/test" hx-ext="path-deps">Click Me!</button>')
+ var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/*/child/test">FOO</div>')
+ 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('<button hx-post="/test/child/test" hx-ext="path-deps">Click Me!</button>')
+ var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test/*/test">FOO</div>')
+ 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('<button hx-post="/test/child/test" hx-ext="path-deps">Click Me!</button>')
+ var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/test/child/*">FOO</div>')
+ 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('<button hx-post="/test/child/test" hx-ext="path-deps">Click Me!</button>')
+ var div = make('<div hx-get="/test2" hx-trigger="path-deps" path-deps="/*/*/*">FOO</div>')
+ btn.click();
+ this.server.respond();
+ btn.innerHTML.should.equal("Clicked!");
+ div.innerHTML.should.equal("FOO");
+ this.server.respond();
+ div.innerHTML.should.equal("Deps fired!");
+ });
+
+
+}); \ No newline at end of file