2015-05-21 12:07:52 -04:00
|
|
|
/// <reference path="../typings/node/node.d.ts" />
|
|
|
|
/// <reference path="../typings/jasmine/jasmine.d.ts" />
|
|
|
|
|
|
|
|
let mockfs = require('mock-fs');
|
|
|
|
import fs = require('fs');
|
|
|
|
import {TreeDiffer} from './tree-differ';
|
|
|
|
import {MergeTrees} from './broccoli-merge-trees';
|
|
|
|
|
|
|
|
describe('MergeTrees', () => {
|
|
|
|
afterEach(() => mockfs.restore());
|
|
|
|
|
|
|
|
function mergeTrees(inputPaths, cachePath, options) {
|
|
|
|
return new MergeTrees(inputPaths, cachePath, options);
|
|
|
|
}
|
|
|
|
|
|
|
|
function MakeTreeDiffers(rootDirs) {
|
|
|
|
let treeDiffers = rootDirs.map((rootDir) => new TreeDiffer('MergeTrees', rootDir));
|
|
|
|
treeDiffers.diffTrees = () => { return treeDiffers.map(tree => tree.diffTree()); };
|
|
|
|
return treeDiffers;
|
|
|
|
}
|
|
|
|
|
2016-04-07 20:17:50 -04:00
|
|
|
function read(path) { return fs.readFileSync(path, 'utf-8'); }
|
2015-05-21 12:07:52 -04:00
|
|
|
|
2015-06-04 17:39:53 -04:00
|
|
|
it('should copy the file from the right-most inputTree with overwrite=true', () => {
|
2015-05-21 12:07:52 -04:00
|
|
|
let testDir: any = {
|
|
|
|
'tree1': {'foo.js': mockfs.file({content: 'tree1/foo.js content', mtime: new Date(1000)})},
|
|
|
|
'tree2': {'foo.js': mockfs.file({content: 'tree2/foo.js content', mtime: new Date(1000)})},
|
|
|
|
'tree3': {'foo.js': mockfs.file({content: 'tree3/foo.js content', mtime: new Date(1000)})}
|
|
|
|
};
|
|
|
|
mockfs(testDir);
|
|
|
|
let treeDiffer = MakeTreeDiffers(['tree1', 'tree2', 'tree3']);
|
2015-06-04 17:39:53 -04:00
|
|
|
let treeMerger = mergeTrees(['tree1', 'tree2', 'tree3'], 'dest', {overwrite: true});
|
2015-05-21 12:07:52 -04:00
|
|
|
treeMerger.rebuild(treeDiffer.diffTrees());
|
|
|
|
expect(read('dest/foo.js')).toBe('tree3/foo.js content');
|
|
|
|
|
|
|
|
delete testDir.tree2['foo.js'];
|
|
|
|
delete testDir.tree3['foo.js'];
|
|
|
|
mockfs(testDir);
|
|
|
|
treeMerger.rebuild(treeDiffer.diffTrees());
|
|
|
|
expect(read('dest/foo.js')).toBe('tree1/foo.js content');
|
|
|
|
|
|
|
|
testDir.tree2['foo.js'] = mockfs.file({content: 'tree2/foo.js content', mtime: new Date(1000)});
|
|
|
|
mockfs(testDir);
|
|
|
|
treeMerger.rebuild(treeDiffer.diffTrees());
|
|
|
|
expect(read('dest/foo.js')).toBe('tree2/foo.js content');
|
|
|
|
});
|
2015-06-04 17:39:53 -04:00
|
|
|
|
2015-05-31 20:24:21 -04:00
|
|
|
it('should throw if duplicates are found during the initial build', () => {
|
2015-06-04 17:39:53 -04:00
|
|
|
let testDir: any = {
|
|
|
|
'tree1': {'foo.js': mockfs.file({content: 'tree1/foo.js content', mtime: new Date(1000)})},
|
|
|
|
'tree2': {'foo.js': mockfs.file({content: 'tree2/foo.js content', mtime: new Date(1000)})},
|
|
|
|
'tree3': {'foo.js': mockfs.file({content: 'tree3/foo.js content', mtime: new Date(1000)})}
|
|
|
|
};
|
|
|
|
mockfs(testDir);
|
|
|
|
let treeDiffer = MakeTreeDiffers(['tree1', 'tree2', 'tree3']);
|
|
|
|
let treeMerger = mergeTrees(['tree1', 'tree2', 'tree3'], 'dest', {});
|
2015-06-12 10:50:45 -04:00
|
|
|
expect(() => treeMerger.rebuild(treeDiffer.diffTrees()))
|
2015-06-16 12:24:29 -04:00
|
|
|
.toThrowError(
|
|
|
|
'Duplicate path found while merging trees. Path: "foo.js".\n' +
|
|
|
|
'Either remove the duplicate or enable the "overwrite" option for this merge.');
|
2015-06-04 17:39:53 -04:00
|
|
|
|
2015-05-31 20:24:21 -04:00
|
|
|
testDir = {
|
|
|
|
'tree1': {'foo.js': mockfs.file({content: 'tree1/foo.js content', mtime: new Date(1000)})},
|
|
|
|
'tree2': {},
|
|
|
|
'tree3': {}
|
|
|
|
};
|
|
|
|
mockfs(testDir);
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('should throw if duplicates are found during rebuild', () => {
|
|
|
|
let testDir = {
|
|
|
|
'tree1': {'foo.js': mockfs.file({content: 'tree1/foo.js content', mtime: new Date(1000)})},
|
|
|
|
'tree2': {},
|
|
|
|
'tree3': {}
|
|
|
|
};
|
2015-06-04 17:39:53 -04:00
|
|
|
mockfs(testDir);
|
2015-05-31 20:24:21 -04:00
|
|
|
|
|
|
|
let treeDiffer = MakeTreeDiffers(['tree1', 'tree2', 'tree3']);
|
|
|
|
let treeMerger = mergeTrees(['tree1', 'tree2', 'tree3'], 'dest', {});
|
2015-06-04 17:39:53 -04:00
|
|
|
expect(() => treeMerger.rebuild(treeDiffer.diffTrees())).not.toThrow();
|
|
|
|
|
2015-05-31 20:24:21 -04:00
|
|
|
|
2015-06-04 17:39:53 -04:00
|
|
|
testDir.tree2['foo.js'] = mockfs.file({content: 'tree2/foo.js content', mtime: new Date(1000)});
|
|
|
|
mockfs(testDir);
|
2015-06-12 10:50:45 -04:00
|
|
|
expect(() => treeMerger.rebuild(treeDiffer.diffTrees()))
|
2015-06-16 12:24:29 -04:00
|
|
|
.toThrowError(
|
|
|
|
'Duplicate path found while merging trees. Path: "foo.js".\n' +
|
|
|
|
'Either remove the duplicate or enable the "overwrite" option for this merge.');
|
2015-06-04 17:39:53 -04:00
|
|
|
});
|
2015-05-21 12:07:52 -04:00
|
|
|
});
|