From dea27a2783e9712cc4aa36bd5a859c86816982ce Mon Sep 17 00:00:00 2001 From: Lionel Bijaoui Date: Tue, 23 Aug 2016 15:43:42 +0200 Subject: [PATCH] test: progress on noUiSlider --- .../unit/specs/fields/fieldNoUiSlider.spec.js | 66 +++++++++++++++---- 1 file changed, 55 insertions(+), 11 deletions(-) diff --git a/test/unit/specs/fields/fieldNoUiSlider.spec.js b/test/unit/specs/fields/fieldNoUiSlider.spec.js index 609aab28..d6767c3f 100644 --- a/test/unit/specs/fields/fieldNoUiSlider.spec.js +++ b/test/unit/specs/fields/fieldNoUiSlider.spec.js @@ -36,27 +36,71 @@ describe("fieldNoUiSlider.vue", () => { expect(field.$el).to.be.exist; expect(input).to.be.defined; - expect(input.classList.contains("slider")).to.be.true; + expect(input.classList.contains("slider")).to.be.true; + expect(input.disabled).to.be.undefined; }); before( () => { - vm.$appendTo(document.body); + vm.$appendTo(document.body); }); - it("should only test in the correct environment", (done) => { + it("should contain an handle element", (done) => { if (window.noUiSlider) { - // make assertions - it("should contain a complex div element", (done) => { - vm.$nextTick( () => { - expect(input).to.be.defined; - expect(input.classList.contains("noui-target")).to.be.true; - done(); - }); + vm.$nextTick( () => { + let handle = input.querySelectorAll(".noUi-handle"); + expect(handle.length).to.be.equal(1); + expect(handle[0]).to.be.defined; + // expect(input.classList.contains("noui-target")).to.be.true; + done(); }); - } else { this.skip(); } }); + + it.skip("should contain the value", (done) => { + vm.$nextTick( () => { + let origin = input.querySelectorAll(".noUi-origin")[0]; + expect(origin.style.left).to.be.within("70%", "90%"); + done(); + }); + }); + + before( () => { + vm.model = { rating: 10 }; + }); + + it("handle value should be the model value after changed", (done) => { + vm.$nextTick( () => { + let origin = input.querySelectorAll(".noUi-origin")[0]; + expect(origin.style.left).to.be.equal("100%"); + done(); + }); + }); + + // before( (done) => { + // input.querySelectorAll(".noUi-origin")[0].style.left = "0%"; + // vm.$nextTick( () => { + // done(); + // }); + // }); + + it.skip("model value should be the handle value after changed", (done) => { + vm.$nextTick( () => { + expect(vm.model.rating).to.be.equal("0"); + done(); + }); + }); + + it.skip("should set disabled", (done) => { + console.log(field.disabled); + console.log(input); + vm.schema.disabled = true; + vm.$nextTick( () => { + console.log(input); + expect(input.disabled).to.be.true; + done(); + }); + }); }); });