forked from vue-generators/vue-form-generator
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathfieldNoUiSlider.spec.js
106 lines (89 loc) · 2.5 KB
/
fieldNoUiSlider.spec.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
import { expect } from "chai";
import { createVueField } from "../util";
import Vue from "vue";
import fieldNoUiSlider from "src/fields/fieldNoUiSlider.vue";
Vue.component("fieldNoUiSlider", fieldNoUiSlider);
// eslint-disable-next-line
let el, vm, field;
function createField(schema = {}, model = null, disabled = false, options) {
[ el, vm, field ] = createVueField("fieldNoUiSlider", schema, model, disabled, options);
}
describe("fieldNoUiSlider.vue", () => {
describe("check template", () => {
let schema = {
type: "range",
label: "Rating",
model: "rating",
min: 1,
max: 10
};
let model = { rating: 8 };
let input;
before( () => {
createField(schema, model, false);
input = el.getElementsByClassName("slider")[0];
});
it("should contain a div element", () => {
expect(field).to.be.exist;
expect(field.$el).to.be.exist;
expect(input).to.be.defined;
expect(input.classList.contains("slider")).to.be.true;
expect(input.disabled).to.be.undefined;
});
before( () => {
vm.$appendTo(document.body);
});
it("should contain an handle element", (done) => {
if (window.noUiSlider) {
vm.$nextTick( () => {
let handle = input.querySelector(".noUi-handle");
expect(handle).to.be.defined;
// expect(input.classList.contains("noui-target")).to.be.true;
done();
});
} else {
// eslint-disable-next-line
throw new Exception("Library is not loaded");
}
});
it.skip("should contain the value", (done) => {
vm.$nextTick( () => {
let origin = input.querySelector(".noUi-origin");
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.querySelector(".noUi-origin");
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();
});
});
});
});