grunt-htmltidy
Version:
Tidy HTML files using htmltidy.
77 lines (64 loc) • 1.65 kB
JavaScript
/*
* grunt-htmltidy
* https://github.com/gav/grunt-htmltidy
*
* Copyright (c) 2014 Gavin Ballard
* Licensed under the MIT license.
*/
'use strict';
module.exports = function(grunt) {
// Project configuration.
grunt.initConfig({
jshint: {
all: [
'Gruntfile.js',
'tasks/*.js',
'<%= nodeunit.tests %>'
],
options: {
jshintrc: '.jshintrc'
}
},
// Before generating any new files, remove any previously-created files.
clean: {
tests: ['tmp']
},
// Configuration to be run (and then tested).
htmltidy: {
options: {},
compile: {
files: {
'tmp/test.html': ['test/fixtures/test.html']
}
},
compileMultiple: {
files: [{
expand: true,
cwd: 'test/fixtures',
src: 'multiple*.html',
dest: 'tmp/'
}]
},
empty: {
files: {
'tmp/idontexist.html': ['test/fixtures/idontexist.html']
}
}
},
// Unit tests.
nodeunit: {
tests: ['test/*_test.js']
}
});
// Actually load this plugin's task(s).
grunt.loadTasks('tasks');
// These plugins provide necessary tasks.
grunt.loadNpmTasks('grunt-contrib-jshint');
grunt.loadNpmTasks('grunt-contrib-clean');
grunt.loadNpmTasks('grunt-contrib-nodeunit');
// Whenever the "test" task is run, first clean the "tmp" dir, then run this
// plugin's task(s), then test the result.
grunt.registerTask('test', ['clean', 'htmltidy', 'nodeunit']);
// By default, lint and run all tests.
grunt.registerTask('default', ['jshint', 'test']);
};