[deploy] fix bug 55493

pull/1586/head
Maxim Kadushkin 2022-02-20 00:37:16 +03:00
parent 65fc046284
commit c489b65bf2
30 changed files with 860 additions and 6 deletions

1
.gitignore vendored
View File

@ -3,6 +3,7 @@ Thumbs.db
.DS_Store
/deploy
build/node_modules
build/plugins/**/node_modules/
build/sprites/node_modules/
vendor/framework7-react/
apps/documenteditor/embed/resources/less/node_modules

View File

@ -106,7 +106,7 @@ module.exports = function(grunt) {
grunt.loadNpmTasks('grunt-json-minify');
grunt.loadNpmTasks('grunt-text-replace');
// grunt.loadNpmTasks('grunt-mocha');
// grunt.loadNpmTasks('grunt-inline');
grunt.loadNpmTasks('grunt-inline');
grunt.loadNpmTasks('grunt-svgmin');
grunt.loadNpmTasks('grunt-exec');
@ -396,9 +396,9 @@ module.exports = function(grunt) {
localization: {
files: packageFile['main']['copy']['localization']
},
help: {
files: packageFile['main']['copy']['help']
},
// help: {
// files: packageFile['main']['copy']['help']
// },
indexhtml: {
files: packageFile['main']['copy']['indexhtml']
}
@ -660,7 +660,7 @@ module.exports = function(grunt) {
grunt.registerTask('deploy-common-embed', ['common-embed-init', 'clean', 'copy']);
grunt.registerTask('deploy-app-main', ['prebuild-icons-sprite', 'main-app-init', 'clean:prebuild', 'imagemin', 'less',
'requirejs', 'concat', 'copy', 'svgmin', /*'inline',*/ 'json-minify',
'requirejs', 'concat', 'copy', 'svgmin', 'inline', 'json-minify',
'replace:writeVersion', 'replace:prepareHelp', 'clean:postbuild']);
grunt.registerTask('deploy-app-mobile', ['mobile-app-init', 'clean:deploy', /*'cssmin',*/ /*'copy:template-backup',*/

View File

@ -4,7 +4,7 @@
"homepage": "http://www.onlyoffice.com",
"private": true,
"dependencies": {
"grunt": "^1.0.0",
"grunt": "^1.4.1",
"grunt-contrib-clean": "^2.0.0",
"grunt-contrib-concat": "^2.0.0",
"grunt-contrib-copy": "^1.0.0",
@ -15,6 +15,7 @@
"grunt-contrib-requirejs": "^1.0.0",
"grunt-contrib-uglify": "^5.0.1",
"grunt-exec": "^3.0.0",
"grunt-inline": "file:plugins/grunt-inline",
"grunt-json-minify": "^1.1.0",
"grunt-spritesmith": "^6.9.0",
"grunt-svgmin": "^6.0.1",

View File

@ -0,0 +1,50 @@
'use strict';
module.exports = function(grunt) {
grunt.initConfig({
inline: {
dist: {
src: ['test/dist/*.html'],
dest: ['tmp/']
}
},
clean: {
tests: ['tmp/']
},
htmlmin: {
dist: {
options: {
removeComments: true,
collapseWhitespace: true
},
files: {
'tmp/css.min.html': 'tmp/css.html',
'tmp/img.min.html': 'tmp/img.html',
'tmp/html.min.html': 'tmp/html.html',
'tmp/script.min.html': 'tmp/script.html',
'tmp/css_greedy.min.html': 'tmp/css_greedy.html',
'tmp/img_greedy.min.html': 'tmp/img_greedy.html',
'tmp/html_greedy.min.html': 'tmp/html_greedy.html',
'tmp/script_greedy.min.html': 'tmp/script_greedy.html'
}
}
},
// Unit tests
nodeunit: {
tests: ['test/*_test.js']
}
});
grunt.loadTasks('tasks');
grunt.loadNpmTasks('grunt-contrib-clean');
grunt.loadNpmTasks('grunt-contrib-htmlmin');
grunt.loadNpmTasks('grunt-contrib-nodeunit');
grunt.registerTask('test', ['clean', 'inline', 'htmlmin', 'nodeunit']);
// By default, run all tests
grunt.registerTask('default', ['test']);
};

View File

@ -0,0 +1,22 @@
Copyright (c) 2014 陈映平, contributors
Permission is hereby granted, free of charge, to any person
obtaining a copy of this software and associated documentation
files (the "Software"), to deal in the Software without
restriction, including without limitation the rights to use,
copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the
Software is furnished to do so, subject to the following
conditions:
The above copyright notice and this permission notice shall be
included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
OTHER DEALINGS IN THE SOFTWARE.

View File

@ -0,0 +1,274 @@
# grunt-inline[![build status](https://secure.travis-ci.org/miniflycn/grunt-inline.png)](http://travis-ci.org/miniflycn/grunt-inline)
Brings externally referenced resources, such as js, css and images, into
a single file.
For exmample:
```html
<link href="css/style.css?__inline=true" rel="stylesheet" />
```
is replaced with
```html
<style>
/* contents of css/style.css */
</style>
```
JavaScript references are brought inline, and images in the html
and css blocks are converted to base-64 data: urls.
By default, only urls marked with `__inline` are converted, however this
behavior can be overrided via the `tag:` option.
## Getting Started
This plugin requires Grunt `~0.4.1`
If you haven't used [Grunt](http://gruntjs.com/) before, be sure to check out the [Getting Started](http://gruntjs.com/getting-started) guide, as it explains how to create a [Gruntfile](http://gruntjs.com/sample-gruntfile) as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:
```bash
npm install grunt-inline --save-dev
```
Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
```bash
grunt.loadNpmTasks('grunt-inline');
```
## The "grunt-inline" task
### Overview
In your project's Gruntfile, add a section named `inline` to the data object passed into `grunt.initConfig()`.
```javascript
grunt.initConfig({
inline: {
dist: {
src: 'src/index.html',
dest: 'dist/index.html'
}
}
});
```
### Options
#### dest
If dest is assigned, the the source file will be copied to the destination path. eg:
`src/index.html` will be processed and then copied to `dist/index.html`
```javascript
grunt.initConfig({
inline: {
dist: {
src: 'src/index.html',
dest: 'dist/index.html'
}
}
});
```
### cssmin
If cssmin is assigned true, `.css` will be minified before inlined.
```javascript
grunt.initConfig({
inline: {
dist: {
options:{
cssmin: true
},
src: 'src/index.html',
dest: 'dist/index.html'
}
}
});
```
### tag (defaults to ```__inline```)
Only URLs that contain the value for ```tag``` will be inlined.
Specify ```tag: ''``` to include all urls.
```javascript
grunt.initConfig({
inline: {
dist: {
options:{
tag: ''
},
src: 'src/index.html',
dest: 'dist/index.html']
}
}
});
```
### inlineTagAttributes
Ability to add attributes string to inline tag.
```javascript
grunt.initConfig({
inline: {
dist: {
options:{
inlineTagAttributes: {
js: 'data-inlined="true"', // Adds <script data-inlined="true">...</script>
css: 'data-inlined="true"' // Adds <style data-inlined="true">...</style>
},
src: 'src/index.html',
dest: 'dist/index.html'
}
}
}
});
```
### uglify
If uglify is assigned true, `.js` file will be minified before inlined.
```javascript
grunt.initConfig({
inline: {
dist: {
options:{
uglify: true
},
src: 'src/index.html',
dest: 'dist/index.html'
}
}
});
```
### exts
Setting an exts array allows multiple file extensions to be processed as
html.
```javascript
grunt.initConfig({
inline: {
dist: {
options:{
exts: ['jade'],
uglify: true
},
src: 'src/index.jade',
dest: 'dist/index.jade'
}
}
});
```
### Usage Examples
> config
```javascript
grunt.initConfig({
inline: {
dist: {
src: 'src/index.html'
}
}
});
```
>src/index.html
```html
<html>
<head>
<title>demo</title>
<link href="css/style.css?__inline=true" rel="stylesheet" />
</head>
<body>
<img src="img/icon.png?__inline=true" />
<script src="js/erport.js?__inline=true"></script>
</body>
</html>
```
after `grunt inline` was run, it will be something like
```html
<html>
<head>
<title>demo</title>
<style>
.container{
padding: 0;
}
</style>
</head>
<body>
<! -- base64, a terrible mass you know…so just show a little bit ...-->
<img src="idata:image/png;base64..." />
<script>
var Report = (function(){
return {
init: function(){
}
};
})();
</script>
</body>
</html>
```
#### inline tag
Suppose there is an `<inline>` tag in `index.html` like bellow
```html
<!-- inline tag -->
<inline src="test.html" />
```
The content of `test.html` is
```html
<p>I'm inline html</p>
<span>hello world!</span>
```
Then, after the `inline` task is run, the original content in `index.html` will be replaced with
```html
<p>I'm inline html</p>
<span>hello world!</span>
```
## Contributing
In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using [Grunt](http://gruntjs.com/).
## Release History
* 2019-12-20 v0.3.7 document optimized: markdown style problems of README
* 2015-01-09 v0.3.3 bug fix: when processing files of a folder and then copy the processed content to another destination, the original files are changed unexpectedly, as mentioned in this issue [Support file globbing for input and output](https://github.com/chyingp/grunt-inline/issues/35)
* 2014-06-16 v0.3.1 bug fix: protocol-relative urls in css are messed up
* 2014-06-15 v0.3.1 bug fix: when options.tag is '', then all img tags, whose src attribute has already been inlined will be matched.
* 2014-05-19 v0.3.0 support for new options.exts
* 2014-05-19 v0.2.9 bug fix: options.tag is assigned '', bug image url in css are not converted to base64 formate
* 2014-03-06 v0.2.6 bug fix: script tags like <script src="index.js?__inline">\n</script> were not inlined
* 2014-01-31 v0.2.3 radded tag option, encode url(..) images.
* 2013-10-31v0.2.2bug fix: img urls like 'background: url(http://www.example.com/img/bg.png)' will be transformed to 'background: url(url(http://www.example.com/img/bg.png))'
* 2013-10-30v0.2.1bug fix: when processing relative file path of img url in css stylesheet, forgot to transform "\" to "/" for windows users
* 2013-10-30v0.2.0new feature: Support for minifing js、css when they ar inlined into html.
* 2013-08-30v0.1.9bug fix: stylesheets ended with ">" cannot be inlined
* 2013-09-02v0.1.9add feature: add options.dest to assign a destination path where the source file will be copied
* 2013-09-02v0.1.8add feature: support for `<inline>` tag

View File

@ -0,0 +1,40 @@
{
"author": {
"name": "程序猿小卡",
"email": "chyingp@gmail.com",
"url": "https://github.com/chyingp"
},
"name": "grunt-inline",
"description": "Inlines img, script and link tags into the same file.",
"version": "0.3.7",
"keywords": [
"gruntplugin",
"inline",
"js",
"css"
],
"main": "inline",
"repository": {
"type": "git",
"url": "https://github.com/chyingp/grunt-inline.git"
},
"engines": {
"node": ">=0.8.0"
},
"devDependencies": {
"grunt-contrib-nodeunit": "^4.0.0",
"grunt-contrib-clean": "^2.0.0",
"grunt-contrib-htmlmin": "^3.1.0",
"grunt": "^1.4.0"
},
"dependencies": {
"uglify-js": "^3.15.1",
"datauri": "^4.1.0",
"clean-css": "^5.2.4"
},
"scripts": {
"test": "grunt test"
},
"_id": "grunt-inline@0.1.0",
"_from": "grunt-inline@~0.1.0"
}

View File

@ -0,0 +1,256 @@
/*
* grunt-inline
* https://github.com/chyingp/grunt-inline
*
* Copyright (c) 2015 Auguest G. casper & IMWEB TEAM
*/
'use strict';
module.exports = function(grunt) {
var path = require('path');
var datauri = require('datauri');
var UglifyJS = require("uglify-js");
var CleanCSS = require('clean-css');
grunt.registerMultiTask('inline', "Replaces <link>, <script> and <img> tags to their inline contents", function() {
var options = this.options({tag: '__inline'}),
uglify = !!options.uglify,
cssmin = !!options.cssmin,
relativeTo = this.options().relativeTo,
exts = options.exts,
dest = this.data.dest,
isExpandedPair;
this.files.forEach(function(filePair){
isExpandedPair = filePair.orig.expand || false;
filePair.src.forEach(function(filepath){
var fileType = path.extname(filepath).replace(/^\./, '');
var fileContent = grunt.file.read(filepath);
var destFilepath = '';
grunt.log.write('Processing ' + filepath + '...')
if(fileType==='html' || (exts && exts.indexOf(fileType) > -1)){
fileContent = html(filepath, fileContent, relativeTo, options);
}else if(fileType==='css'){
fileContent = css(filepath, fileContent, relativeTo, options);
}
if(detectDestType(filePair.dest) === 'directory') {
destFilepath = (isExpandedPair) ? filePair.dest : unixifyPath(path.join(filePair.dest, filepath));
}else{
destFilepath = filePair.dest || filepath;
}
grunt.file.write(destFilepath, fileContent);
grunt.log.ok()
});
});
});
function isRemotePath( url ){
return url.match(/^'?https?:\/\//) || url.match(/^\/\//);
}
function isBase64Path( url ){
return url.match(/^'?data.*base64/);
}
// code from grunt-contrib-copy, with a little modification
function detectDestType(dest) {
if (grunt.util._.endsWith(dest, '/')) {
return 'directory';
} else {
return 'file';
}
}
function unixifyPath(filepath) {
if (process.platform === 'win32') {
return filepath.replace(/\\/g, '/');
} else {
return filepath;
}
}
// from grunt-text-replace.js in grunt-text-replace
function getPathToDestination(pathToSource, pathToDestinationFile) {
var isDestinationDirectory = (/\/$/).test(pathToDestinationFile);
var fileName = path.basename(pathToSource);
var newPathToDestination;
if (typeof pathToDestinationFile === 'undefined') {
newPathToDestination = pathToSource;
} else {
newPathToDestination = pathToDestinationFile + (isDestinationDirectory ? fileName : '');
}
return newPathToDestination;
}
function html(filepath, fileContent, relativeTo, options){
if(relativeTo){
filepath = filepath.replace(/[^\/]+\//, relativeTo);
}
fileContent = fileContent.replace(/<inline.+?src=["']([^"']+?)["']\s*?\/>/g, function(matchedWord, src){
var ret = matchedWord;
if(isRemotePath(src) || !grunt.file.isPathAbsolute(src)){
var inlineFilePath = path.resolve( path.dirname(filepath), src );
if( grunt.file.exists(inlineFilePath) ){
ret = grunt.file.read( inlineFilePath );
// @otod need to be checked, add bye herbert
var _more = src.match(/^(..\/)+/ig);
if(_more = _more && _more[0]){
var _addMore = function(){
var _ret = arguments[0],_src = arguments[2];
if(!_src.match(/^http\:\/\//)){
_ret =arguments[1] + _more + arguments[2] + arguments[3];
grunt.log.writeln('inline >含有相对目录进行替换操作,替换之后的路径:' + _ret );
}
return _ret;
}
ret = ret.replace(/(<script.+?src=["'])([^"']+?)(["'].*?><\/script>)/g,_addMore);
}
}else{
grunt.log.error("Couldn't find " + inlineFilePath + '!');
}
}
return ret;
}).replace(/<script.+?src=["']([^"']+?)["'].*?>\s*<\/script>/g, function(matchedWord, src){
var ret = matchedWord;
if(!isRemotePath(src) && src.indexOf(options.tag)!=-1){
var inlineFilePath = path.resolve( path.dirname(filepath), src ).replace(/\?.*$/, ''); // 将参数去掉
if( grunt.file.exists(inlineFilePath) ) {
const rawstr = grunt.file.read(inlineFilePath);
let c = rawstr;
if ( options.uglify ) {
const uglstr = UglifyJS.minify(rawstr);
if ( uglstr.error == undefined )
c = uglstr.code;
else grunt.log.error("uglify error " + uglstr.code);
}
ret = '<script>\n' + c + '\n</script>';
}else{
grunt.log.error("Couldn't find " + inlineFilePath + '!');
}
}
grunt.log.debug('ret = : ' + ret +'\n');
return ret;
}).replace(/<link.+?href=["']([^"']+?)["'].*?\/?>/g, function(matchedWord, src){
var ret = matchedWord;
if(!isRemotePath(src) && src.indexOf(options.tag)!=-1){
var inlineFilePath = path.resolve( path.dirname(filepath), src ).replace(/\?.*$/, ''); // 将参数去掉
if( grunt.file.exists(inlineFilePath) ){
var styleSheetContent = grunt.file.read( inlineFilePath );
ret = '<style>\n' + cssInlineToHtml(filepath, inlineFilePath, styleSheetContent, relativeTo, options) + '\n</style>';
}else{
grunt.log.error("Couldn't find " + inlineFilePath + '!');
}
}
grunt.log.debug('ret = : ' + ret +'\n');
return ret;
}).replace(/<img.+?src=["']([^"':]+?)["'].*?\/?\s*?>/g, function(matchedWord, src){
var ret = matchedWord;
if(!grunt.file.isPathAbsolute(src) && src.indexOf(options.tag)!=-1){
var inlineFilePath = path.resolve( path.dirname(filepath), src ).replace(/\?.*$/, ''); // 将参数去掉
if( grunt.file.exists(inlineFilePath) ){
ret = matchedWord.replace(src, (new datauri(inlineFilePath)).content);
}else{
grunt.log.error("Couldn't find " + inlineFilePath + '!');
}
}
grunt.log.debug('ret = : ' + ret +'\n');
return ret;
});
return fileContent;
}
function css(filepath, fileContent, relativeTo, options) {
if(relativeTo){
filepath = filepath.replace(/[^\/]+\//g, relativeTo);
}
fileContent = fileContent.replace(/url\(["']*([^)'"]+)["']*\)/g, function(matchedWord, imgUrl){
var newUrl = imgUrl;
var flag = imgUrl.indexOf(options.tag)!=-1; // urls like "img/bg.png?__inline" will be transformed to base64
if(isBase64Path(imgUrl) || isRemotePath(imgUrl)){
return matchedWord;
}
grunt.log.debug( 'imgUrl: '+imgUrl);
grunt.log.debug( 'filepath: '+filepath);
var absoluteImgurl = path.resolve( path.dirname(filepath),imgUrl );
grunt.log.debug( 'absoluteImgurl: '+absoluteImgurl);
newUrl = path.relative( path.dirname(filepath), absoluteImgurl );
grunt.log.debug( 'newUrl: '+newUrl);
absoluteImgurl = absoluteImgurl.replace(/\?.*$/, '');
if(flag && grunt.file.exists(absoluteImgurl)){
newUrl = datauri(absoluteImgurl);
}else{
newUrl = newUrl.replace(/\\/g, '/');
}
return matchedWord.replace(imgUrl, newUrl);
});
fileContent = options.cssmin ? CleanCSS.process(fileContent) : fileContent;
return fileContent;
}
function cssInlineToHtml(htmlFilepath, filepath, fileContent, relativeTo, options) {
if(relativeTo){
filepath = filepath.replace(/[^\/]+\//g, relativeTo);
}
fileContent = fileContent.replace(/url\(["']*([^)'"]+)["']*\)/g, function(matchedWord, imgUrl){
var newUrl = imgUrl;
var flag = !!imgUrl.match(/\?__inline/); // urls like "img/bg.png?__inline" will be transformed to base64
grunt.log.debug('flag:'+flag);
if(isBase64Path(imgUrl) || isRemotePath(imgUrl)){
return matchedWord;
}
grunt.log.debug( 'imgUrl: '+imgUrl);
grunt.log.debug( 'filepath: '+filepath);
var absoluteImgurl = path.resolve( path.dirname(filepath),imgUrl ); // img url relative to project root
grunt.log.debug( 'absoluteImgurl: '+absoluteImgurl);
newUrl = path.relative( path.dirname(htmlFilepath), absoluteImgurl ); // img url relative to the html file
grunt.log.debug([htmlFilepath, filepath, absoluteImgurl, imgUrl]);
grunt.log.debug( 'newUrl: '+newUrl);
absoluteImgurl = absoluteImgurl.replace(/\?.*$/, '');
if(flag && grunt.file.exists(absoluteImgurl)){
newUrl = datauri(absoluteImgurl);
}else{
newUrl = newUrl.replace(/\\/g, '/');
}
return matchedWord.replace(imgUrl, newUrl);
});
fileContent = options.cssmin ? CleanCSS.process(fileContent) : fileContent;
return fileContent;
}
};

View File

@ -0,0 +1,13 @@
<!DOCTYPE html>
<html>
<head>
<title>test</title>
<!-- ended with "/>" -->
<link href="styles/main.css?__inline=true" rel="stylesheet" />
<!-- ended with ">" -->
<link href="styles/main.css?__inline=true" rel="stylesheet">
</head>
<body>
</body>
</html>

View File

@ -0,0 +1,9 @@
<!DOCTYPE html>
<html>
<head>
<title>test</title>
<link href="styles/main.css?__inline=true" rel="stylesheet" /><link href="styles/main.css?__inline=true" rel="stylesheet">
</head>
<body>
</body>
</html>

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html>
<head>
<title>test</title>
</head>
<body>
<!-- inline html -->
<inline src="html/test.html" />
</body>
</html>

View File

@ -0,0 +1 @@
<p>test</p>

View File

@ -0,0 +1,9 @@
<!DOCTYPE html>
<html>
<head>
<title>test</title>
</head>
<body>
<inline src="html/test.html" /><inline src="html/test.html" />
</body>
</html>

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html>
<head>
<title>test</title>
</head>
<body>
<!-- inline image -->
<img src="img/icon.png?__inline=true" />
</body>
</html>

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

View File

@ -0,0 +1,9 @@
<!DOCTYPE html>
<html>
<head>
<title>test</title>
</head>
<body>
<img src="img/icon.png?__inline=true" /><img src="img/icon.png?__inline=true" />
</body>
</html>

View File

@ -0,0 +1 @@
console.log('test');

View File

@ -0,0 +1,9 @@
<!DOCTYPE html>
<html>
<head>
<title>test</title>
<script src="js/export.js?__inline=true"></script>
</head>
<body>
</body>
</html>

View File

@ -0,0 +1,9 @@
<!DOCTYPE html>
<html>
<head>
<title>test</title>
<script src="js/export.js?__inline=true"></script><script src="js/export.js?__inline=true"></script>
</head>
<body>
</body>
</html>

View File

@ -0,0 +1,6 @@
.main{border: none;}
body{background: url(http://www.example.com/img/bg.png);}
body{background: url('http://www.example.com/img/bg.png');}
body{background: url('../img/icon.png?__inline=true');}
body{background: url()
body{background: url('')

View File

@ -0,0 +1,11 @@
<!DOCTYPE html><html><head><title>test</title><style>.main{border: none;}
body{background: url(http://www.example.com/img/bg.png);}
body{background: url('http://www.example.com/img/bg.png');}
body{background: url('');}
body{background: url()
body{background: url('')</style><style>.main{border: none;}
body{background: url(http://www.example.com/img/bg.png);}
body{background: url('http://www.example.com/img/bg.png');}
body{background: url('');}
body{background: url()
body{background: url('')</style></head><body></body></html>

View File

@ -0,0 +1,11 @@
<!DOCTYPE html><html><head><title>test</title><style>.main{border: none;}
body{background: url(http://www.example.com/img/bg.png);}
body{background: url('http://www.example.com/img/bg.png');}
body{background: url('');}
body{background: url()
body{background: url('')</style><style>.main{border: none;}
body{background: url(http://www.example.com/img/bg.png);}
body{background: url('http://www.example.com/img/bg.png');}
body{background: url('');}
body{background: url()
body{background: url('')</style></head><body></body></html>

View File

@ -0,0 +1 @@
<!DOCTYPE html><html><head><title>test</title></head><body><p>test</p></body></html>

View File

@ -0,0 +1 @@
<!DOCTYPE html><html><head><title>test</title></head><body><p>test</p><p>test</p></body></html>

View File

@ -0,0 +1 @@
<!DOCTYPE html><html><head><title>test</title></head><body><img src=""></body></html>

View File

@ -0,0 +1 @@
<!DOCTYPE html><html><head><title>test</title></head><body><img src=""><img src=""></body></html>

View File

@ -0,0 +1 @@
<!DOCTYPE html><html><head><title>test</title><script>console.log('test');</script></head><body></body></html>

View File

@ -0,0 +1 @@
<!DOCTYPE html><html><head><title>test</title><script>console.log('test');</script><script>console.log('test');</script></head><body></body></html>

View File

@ -0,0 +1,48 @@
var grunt = require('grunt');
var fs = require('fs');
function readFile(file) {
'use strict';
var contents = grunt.file.read(file);
if (process.platform === 'win32') {
contents = contents.replace(/\r\n/g, '\n');
}
return contents;
}
function assertFileEquality(test, pathToActual, pathToExpected, message) {
var actual = readFile(pathToActual);
var expected = readFile(pathToExpected);
test.equal(expected, actual, message);
}
exports.inline = function(test) {
'use strict';
test.expect(4);
assertFileEquality(test,
'tmp/img_greedy.min.html',
'test/expected/img_greedy.min.html',
'Should compile two image target without newline characters');
assertFileEquality(test,
'tmp/css_greedy.min.html',
'test/expected/css_greedy.min.html',
'Should compile two link target without newline characters');
assertFileEquality(test,
'tmp/html_greedy.min.html',
'test/expected/html_greedy.min.html',
'Should compile two inline target without newline characters');
assertFileEquality(test,
'tmp/script_greedy.min.html',
'test/expected/script_greedy.min.html',
'Should compile two script target without newline characters');
test.done();
};

View File

@ -0,0 +1,48 @@
var grunt = require('grunt');
var fs = require('fs');
function readFile(file) {
'use strict';
var contents = grunt.file.read(file);
if (process.platform === 'win32') {
contents = contents.replace(/\r\n/g, '\n');
}
return contents;
}
function assertFileEquality(test, pathToActual, pathToExpected, message) {
var actual = readFile(pathToActual);
var expected = readFile(pathToExpected);
test.equal(expected, actual, message);
}
exports.inline = function(test) {
'use strict';
test.expect(4);
assertFileEquality(test,
'tmp/css.min.html',
'test/expected/css.min.html',
'Should compile css inline');
assertFileEquality(test,
'tmp/img.min.html',
'test/expected/img.min.html',
'Should compile image inline');
assertFileEquality(test,
'tmp/html.min.html',
'test/expected/html.min.html',
'Should compile html inline');
assertFileEquality(test,
'tmp/script.min.html',
'test/expected/script.min.html',
'Should compile script inline');
test.done();
};