describe("hyperscript integration", function() { beforeEach(function () { this.server = makeServer(); clearWorkArea(); }); afterEach(function () { this.server.restore(); clearWorkArea(); }); it('can trigger with a custom event', function () { this.server.respondWith("GET", "/test", "Custom Event Sent!"); var btn = make('') htmx.trigger(btn, "htmx:load"); // have to manually trigger the load event for non-AJAX dynamic content btn.click(); this.server.respond(); btn.innerHTML.should.equal("Custom Event Sent!"); }); it('can handle htmx driven events', function () { this.server.respondWith("GET", "/test", "Clicked!"); var btn = make('') htmx.trigger(btn, "htmx:load"); btn.classList.contains("afterSettle").should.equal(false); btn.click(); this.server.respond(); btn.classList.contains("afterSettle").should.equal(true); }); it('can handle htmx error events', function () { this.server.respondWith("GET", "/test", [404, {}, "Bad request"]); var div = make('
') var btn = make('') htmx.trigger(btn, "htmx:load"); btn.click(); this.server.respond(); div.innerHTML.startsWith("Response Status Error Code 404 from"); }); it('hyperscript in non-htmx annotated nodes is evaluated', function () { this.server.respondWith("GET", "/test", "