mirror of
https://github.com/pa11y/pa11y-dashboard.git
synced 2025-09-25 06:41:21 +00:00
Write basic tests for task editing
This commit is contained in:
@@ -39,13 +39,27 @@ describe('GET /', function () {
|
|||||||
assert.strictEqual(tasks[2].querySelectorAll('[href="/abc000000000000000000003"]').length, 1);
|
assert.strictEqual(tasks[2].querySelectorAll('[href="/abc000000000000000000003"]').length, 1);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should display a delete button for each task', function () {
|
it('should display an "Edit" button for each task', function () {
|
||||||
|
var tasks = this.last.dom.querySelectorAll('[data-test=task]');
|
||||||
|
assert.strictEqual(tasks[0].querySelectorAll('[href="/abc000000000000000000001/edit"]').length, 1);
|
||||||
|
assert.strictEqual(tasks[1].querySelectorAll('[href="/abc000000000000000000002/edit"]').length, 1);
|
||||||
|
assert.strictEqual(tasks[2].querySelectorAll('[href="/abc000000000000000000003/edit"]').length, 1);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should display a "Delete" button for each task', function () {
|
||||||
var tasks = this.last.dom.querySelectorAll('[data-test=task]');
|
var tasks = this.last.dom.querySelectorAll('[data-test=task]');
|
||||||
assert.strictEqual(tasks[0].querySelectorAll('[href="/abc000000000000000000001/delete"]').length, 1);
|
assert.strictEqual(tasks[0].querySelectorAll('[href="/abc000000000000000000001/delete"]').length, 1);
|
||||||
assert.strictEqual(tasks[1].querySelectorAll('[href="/abc000000000000000000002/delete"]').length, 1);
|
assert.strictEqual(tasks[1].querySelectorAll('[href="/abc000000000000000000002/delete"]').length, 1);
|
||||||
assert.strictEqual(tasks[2].querySelectorAll('[href="/abc000000000000000000003/delete"]').length, 1);
|
assert.strictEqual(tasks[2].querySelectorAll('[href="/abc000000000000000000003/delete"]').length, 1);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should display a "Run" button for each task', function () {
|
||||||
|
var tasks = this.last.dom.querySelectorAll('[data-test=task]');
|
||||||
|
assert.strictEqual(tasks[0].querySelectorAll('[href="/abc000000000000000000001/run"]').length, 1);
|
||||||
|
assert.strictEqual(tasks[1].querySelectorAll('[href="/abc000000000000000000002/run"]').length, 1);
|
||||||
|
assert.strictEqual(tasks[2].querySelectorAll('[href="/abc000000000000000000003/run"]').length, 1);
|
||||||
|
});
|
||||||
|
|
||||||
it('should display the task result counts if the task has been run', function () {
|
it('should display the task result counts if the task has been run', function () {
|
||||||
var tasks = this.last.dom.querySelectorAll('[data-test=task]');
|
var tasks = this.last.dom.querySelectorAll('[data-test=task]');
|
||||||
assert.match(tasks[0].textContent, /1\s*errors/i);
|
assert.match(tasks[0].textContent, /1\s*errors/i);
|
||||||
|
@@ -25,6 +25,10 @@ describe('GET /<task-id>/delete', function () {
|
|||||||
assert.strictEqual(form.getAttribute('method'), 'post');
|
assert.strictEqual(form.getAttribute('method'), 'post');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should display a link back to the task page', function () {
|
||||||
|
assert.greaterThan(this.last.dom.querySelectorAll('[href="/abc000000000000000000001"]').length, 0);
|
||||||
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('POST /<task-id>/delete', function () {
|
describe('POST /<task-id>/delete', function () {
|
||||||
|
102
test/functional/route/task/edit.js
Normal file
102
test/functional/route/task/edit.js
Normal file
@@ -0,0 +1,102 @@
|
|||||||
|
/* global beforeEach, describe, it */
|
||||||
|
/* jshint maxlen: false, maxstatements: false */
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var assert = require('proclaim');
|
||||||
|
|
||||||
|
describe('GET /<task-id>/edit', function () {
|
||||||
|
|
||||||
|
beforeEach(function (done) {
|
||||||
|
var req = {
|
||||||
|
method: 'GET',
|
||||||
|
endpoint: '/abc000000000000000000001/edit'
|
||||||
|
};
|
||||||
|
this.navigate(req, done);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should send a 200 status', function () {
|
||||||
|
assert.strictEqual(this.last.status, 200);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should have an "Edit URL" form', function () {
|
||||||
|
var form = this.last.dom.querySelectorAll('[data-test=edit-url-form]')[0];
|
||||||
|
assert.isDefined(form);
|
||||||
|
assert.strictEqual(form.getAttribute('action'), '/abc000000000000000000001/edit');
|
||||||
|
assert.strictEqual(form.getAttribute('method'), 'post');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should display a link back to the task page', function () {
|
||||||
|
assert.greaterThan(this.last.dom.querySelectorAll('[href="/abc000000000000000000001"]').length, 0);
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('"Edit URL" form', function () {
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
this.form = this.last.dom.querySelectorAll('[data-test=edit-url-form]')[0];
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should have a "name" field', function () {
|
||||||
|
var field = this.form.querySelectorAll('input[name=name]')[0];
|
||||||
|
assert.isDefined(field);
|
||||||
|
assert.strictEqual(field.getAttribute('type'), 'text');
|
||||||
|
assert.strictEqual(field.getAttribute('value'), 'NPG Home');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should have a disabled "url" field', function () {
|
||||||
|
var field = this.form.querySelectorAll('input[name=url]')[0];
|
||||||
|
assert.isDefined(field);
|
||||||
|
assert.strictEqual(field.getAttribute('type'), 'url');
|
||||||
|
assert.strictEqual(field.getAttribute('value'), 'nature.com');
|
||||||
|
assert.isDefined(field.getAttribute('disabled'));
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should have a disabled "standard" field', function () {
|
||||||
|
var field = this.form.querySelectorAll('select[name=standard]')[0];
|
||||||
|
assert.isDefined(field);
|
||||||
|
assert.isDefined(field.getAttribute('disabled'));
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should have "ignore" fields', function () {
|
||||||
|
var fields = this.form.querySelectorAll('input[name="ignore[]"]');
|
||||||
|
assert.isDefined(fields);
|
||||||
|
assert.notStrictEqual(fields.length, 0);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('POST /<task-id>/edit', function () {
|
||||||
|
|
||||||
|
beforeEach(function (done) {
|
||||||
|
var req = {
|
||||||
|
method: 'POST',
|
||||||
|
endpoint: '/abc000000000000000000001/edit',
|
||||||
|
body: {
|
||||||
|
name: 'foo',
|
||||||
|
ignore: ['bar', 'baz']
|
||||||
|
}
|
||||||
|
};
|
||||||
|
this.navigate(req, done);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should send a 200 status', function () {
|
||||||
|
assert.strictEqual(this.last.status, 200);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should edit the task', function (done) {
|
||||||
|
this.webservice.task('abc000000000000000000001').get({}, function (err, task) {
|
||||||
|
assert.strictEqual(task.name, 'foo');
|
||||||
|
assert.deepEqual(task.ignore, ['bar', 'baz']);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should display a success message', function () {
|
||||||
|
var alert = this.last.dom.querySelectorAll('[data-test=alert]')[0];
|
||||||
|
assert.isDefined(alert);
|
||||||
|
assert.match(alert.textContent, /been saved/i);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
@@ -20,22 +20,24 @@ describe('GET /<task-id>', function () {
|
|||||||
assert.strictEqual(this.last.status, 200);
|
assert.strictEqual(this.last.status, 200);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should display an "Edit" button', function () {
|
||||||
|
assert.strictEqual(this.last.dom.querySelectorAll('[href="/abc000000000000000000001/edit"]').length, 1);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should display a "Delete" button', function () {
|
||||||
|
assert.strictEqual(this.last.dom.querySelectorAll('[href="/abc000000000000000000001/delete"]').length, 1);
|
||||||
|
});
|
||||||
|
|
||||||
it('should display a "Run" button', function () {
|
it('should display a "Run" button', function () {
|
||||||
var elem = this.last.dom.querySelectorAll('[data-test=run-task]');
|
assert.strictEqual(this.last.dom.querySelectorAll('[href="/abc000000000000000000001/run"]').length, 1);
|
||||||
assert.strictEqual(elem.length, 1);
|
|
||||||
assert.strictEqual(elem[0].getAttribute('href'), '/abc000000000000000000001/run');
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should display a "Download CSV" button for the latest result', function () {
|
it('should display a "Download CSV" button for the latest result', function () {
|
||||||
var elem = this.last.dom.querySelectorAll('[data-test=download-csv]');
|
assert.strictEqual(this.last.dom.querySelectorAll('[href="/abc000000000000000000001/def000000000000000000001.csv"]').length, 1);
|
||||||
assert.strictEqual(elem.length, 1);
|
|
||||||
assert.strictEqual(elem[0].getAttribute('href'), '/abc000000000000000000001/def000000000000000000001.csv');
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should display a "Download JSON" button for the latest result', function () {
|
it('should display a "Download JSON" button for the latest result', function () {
|
||||||
var elem = this.last.dom.querySelectorAll('[data-test=download-json]');
|
assert.strictEqual(this.last.dom.querySelectorAll('[href="/abc000000000000000000001/def000000000000000000001.json"]').length, 1);
|
||||||
assert.strictEqual(elem.length, 1);
|
|
||||||
assert.strictEqual(elem[0].getAttribute('href'), '/abc000000000000000000001/def000000000000000000001.json');
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should display links to all results', function () {
|
it('should display links to all results', function () {
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
{{/content}}
|
{{/content}}
|
||||||
|
|
||||||
{{#edited}}
|
{{#edited}}
|
||||||
<div class="col-md-12 clearfix" data-test="error">
|
<div class="col-md-12 clearfix" data-test="alert">
|
||||||
<div class="alert alert-success">
|
<div class="alert alert-success">
|
||||||
<button aria-hidden="true" data-dismiss="alert" class="close" type="button">×</button>
|
<button aria-hidden="true" data-dismiss="alert" class="close" type="button">×</button>
|
||||||
<strong>Success!</strong>
|
<strong>Success!</strong>
|
||||||
|
Reference in New Issue
Block a user