Skip to content

Commit

Permalink
✅ test: More fields test cases
Browse files Browse the repository at this point in the history
  • Loading branch information
icebob committed May 9, 2016
1 parent b6f9f57 commit c1c57be
Show file tree
Hide file tree
Showing 4 changed files with 403 additions and 0 deletions.
148 changes: 148 additions & 0 deletions test/unit/specs/fields/fieldImage.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,148 @@
import { expect } from "chai";
import { createVueField, trigger } from "../util";

import Vue from "vue";
import FieldImage from "src/fields/fieldImage.vue";

Vue.component("FieldImage", FieldImage);

let el, vm, field;

function createField(schema = {}, model = null, disabled = false, options) {
[ el, vm, field ] = createVueField("fieldImage", schema, model, disabled, options);
}

describe("fieldImage.vue", () => {

describe("check template without preview", () => {
let schema = {
type: "image",
label: "Avatar",
model: "avatar",
readonly: false,
placeholder: "Field placeholder"
};
let model = { avatar: "https://s3.amazonaws.com/uifaces/faces/twitter/calebogden/128.jpg" };
let input;

before( () => {
createField(schema, model, false);
input = el.querySelector("input[type=text]");
});

it("should contain an input text element", () => {
expect(field).to.be.exist;
expect(field.$el).to.be.exist;

expect(input).to.be.defined;
expect(input.classList.contains("form-control")).to.be.true;
expect(input.classList.contains("link")).to.be.true;
expect(input.placeholder).to.be.equal(schema.placeholder);
expect(input.readOnly).to.be.false;
expect(input.disabled).to.be.false;
});

it("should contain a file input element", () => {
let fileInput = el.querySelector("input[type=file]");
expect(fileInput).to.be.defined;
expect(fileInput.classList.contains("form-control")).to.be.true;
expect(fileInput.classList.contains("file")).to.be.true;
expect(fileInput.readOnly).to.be.false;
expect(fileInput.disabled).to.be.false;
});

it("should not visible the preview div", () => {
let preview = el.querySelector(".preview");
expect(preview.style.display).to.be.equal("block");
});


it("should contain the value", (done) => {
vm.$nextTick( () => {
expect(input.value).to.be.equal(model.avatar);
done();
});
});

it("should set readOnly", (done) => {
schema.readonly = true;
vm.$nextTick( () => {
expect(input.readOnly).to.be.true;
done();
});
});

it("should set disabled", (done) => {
field.disabled = true;
vm.$nextTick( () => {
expect(input.disabled).to.be.true;
done();
});
});

it("input value should be the model value after changed", (done) => {
model.avatar = "https://s3.amazonaws.com/uifaces/faces/twitter/felipebsb/128.jpg";
vm.$nextTick( () => {
expect(input.value).to.be.equal("https://s3.amazonaws.com/uifaces/faces/twitter/felipebsb/128.jpg");
done();
});

});

it("model value should be the input value if changed", (done) => {
input.value = "https://s3.amazonaws.com/uifaces/faces/twitter/peterme/128.jpg";
trigger(input, "change");

vm.$nextTick( () => {
expect(model.avatar).to.be.equal("https://s3.amazonaws.com/uifaces/faces/twitter/peterme/128.jpg");
done();
});

});

it("should not contain a file input element if browse is false", (done) => {
vm.$set("schema.browse", false);

vm.$nextTick( () => {
let fileInput = el.querySelector("input[type=file]");
expect(fileInput).to.be.null;
done();
});
});

it("should not visible the preview div", (done) => {
vm.$set("schema.preview", false);

vm.$nextTick( () => {
let preview = el.querySelector(".preview");
expect(preview.style.display).to.be.equal("none");
done();
});
});

it("should not show base64 data in input field", (done) => {
model.avatar = "data:image/jpeg;base64,/9j/4AAQSkZJRgABAQ";

vm.$nextTick( () => {
expect(input.value).to.be.equal("<inline base64 image>");
done();
});
});

it("should clear input if press remove icon", (done) => {
vm.$set("schema.preview", true);
vm.$nextTick( () => {
let remove = el.querySelector(".remove");
expect(input.value).to.be.not.equal("");
remove.click();

vm.$nextTick( () => {
expect(input.value).to.be.equal("");
done();
});
});
});

});

});
91 changes: 91 additions & 0 deletions test/unit/specs/fields/fieldMasked.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,91 @@
import { expect } from "chai";
import { createVueField, trigger } from "../util";

import Vue from "vue";
import FieldMasked from "src/fields/fieldMasked.vue";

Vue.component("FieldMasked", FieldMasked);

let el, vm, field;

function createField(schema = {}, model = null, disabled = false, options) {
[ el, vm, field ] = createVueField("fieldMasked", schema, model, disabled, options);
}

describe("fieldMasked.vue", () => {

describe("check template", () => {
let schema = {
type: "masked",
label: "Phone",
model: "phone",
mask: "(99) 999-9999",
readonly: false,
placeholder: "Field placeholder"
};
let model = { phone: "(30) 123-4567" };
let input;

before( () => {
createField(schema, model, false);
input = el.getElementsByTagName("input")[0];
});

it("should contain an masked input element", () => {
expect(field).to.be.exist;
expect(field.$el).to.be.exist;

expect(input).to.be.defined;
expect(input.type).to.be.equal("text");
expect(input.classList.contains("form-control")).to.be.true;
expect(input.placeholder).to.be.equal(schema.placeholder);
expect(input.readOnly).to.be.false;
expect(input.disabled).to.be.false;
});

it("should contain the value", (done) => {
vm.$nextTick( () => {
expect(input.value).to.be.equal("(30) 123-4567");
done();
});
});

it("should set readOnly", (done) => {
schema.readonly = true;
vm.$nextTick( () => {
expect(input.readOnly).to.be.true;
done();
});
});

it("should set disabled", (done) => {
field.disabled = true;
vm.$nextTick( () => {
expect(input.disabled).to.be.true;
done();
});
});

it("input value should be the model value after changed", (done) => {
model.phone = "(70) 555- 4433";
vm.$nextTick( () => {
expect(input.value).to.be.equal("(70) 555- 4433");
done();
});

});

it("model value should be the input value if changed", (done) => {
input.value = "(21) 888-6655";
trigger(input, "input");

vm.$nextTick( () => {
expect(model.phone).to.be.equal("(21) 888-6655");
done();
});

});

});

});
86 changes: 86 additions & 0 deletions test/unit/specs/fields/fieldSlider.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
import { expect } from "chai";
import { createVueField, trigger } from "../util";

import Vue from "vue";
import FieldSlider from "src/fields/fieldSlider.vue";

Vue.component("FieldSlider", FieldSlider);

let el, vm, field;

function createField(schema = {}, model = null, disabled = false, options) {
[ el, vm, field ] = createVueField("fieldSlider", schema, model, disabled, options);
}

describe("fieldSlider.vue", () => {

describe("check template", () => {
let schema = {
type: "range",
label: "Rating",
model: "rating",
min: 1,
max: 10,
placeholder: "Field placeholder"
};
let model = { rating: 8 };
let input;

before( () => {
createField(schema, model, false);
input = el.getElementsByTagName("input")[0];
//console.log(input);
});

it("should contain an input text element", () => {
expect(field).to.be.exist;
expect(field.$el).to.be.exist;

expect(input).to.be.defined;
expect(input.type).to.be.equal("text");
expect(input.classList.contains("form-control")).to.be.true;
expect(input.placeholder).to.be.equal(schema.placeholder);
expect(input.getAttribute("data-slider-min")).to.be.equal("1");
expect(input.getAttribute("data-slider-max")).to.be.equal("10");
expect(input.disabled).to.be.false;
});

it("should contain the value", (done) => {
vm.$nextTick( () => {
expect(input.getAttribute("data-slider-value")).to.be.equal("8");
expect(input.value).to.be.equal("8");
done();
});
});

it("should set disabled", (done) => {
field.disabled = true;
vm.$nextTick( () => {
expect(input.disabled).to.be.true;
done();
});
});

it("input value should be the model value after changed", (done) => {
model.rating = 3;
vm.$nextTick( () => {
expect(input.value).to.be.equal("3");
done();
});

});

it("model value should be the input value if changed", (done) => {
input.value = "6";
trigger(input, "input");

vm.$nextTick( () => {
expect(model.rating).to.be.equal(6);
done();
});

});

});

});
Loading

0 comments on commit c1c57be

Please sign in to comment.