mirror of
https://github.com/shelljs/shelljs.git
synced 2026-01-18 16:03:37 +00:00
No change to logic. This swaps over tests to use require() since everything is currently designed for the commonjs module system.
138 lines
4.2 KiB
JavaScript
138 lines
4.2 KiB
JavaScript
const fs = require('fs');
|
|
|
|
const test = require('ava');
|
|
|
|
const shell = require('..');
|
|
const common = require('../src/common');
|
|
|
|
shell.config.silent = true;
|
|
|
|
//
|
|
// Invalids
|
|
//
|
|
|
|
test('no args', t => {
|
|
const result = shell.head();
|
|
t.truthy(shell.error());
|
|
t.is(result.code, 1);
|
|
});
|
|
|
|
test('file does not exist', t => {
|
|
t.falsy(fs.existsSync('/asdfasdf')); // sanity check
|
|
const result = shell.head('/asdfasdf'); // file does not exist
|
|
t.truthy(shell.error());
|
|
t.is(result.code, 1);
|
|
t.is(result.stderr, 'head: no such file or directory: /asdfasdf');
|
|
});
|
|
|
|
test('directory', t => {
|
|
t.truthy(common.statFollowLinks('test/resources/').isDirectory()); // sanity check
|
|
const result = shell.head('test/resources/');
|
|
t.truthy(shell.error());
|
|
t.is(result.code, 1);
|
|
t.is(result.stderr, "head: error reading 'test/resources/': Is a directory");
|
|
});
|
|
|
|
//
|
|
// Valids
|
|
//
|
|
|
|
const topOfFile1 = ['file1 1', 'file1 2', 'file1 3', 'file1 4', 'file1 5',
|
|
'file1 6', 'file1 7', 'file1 8', 'file1 9', 'file1 10',
|
|
'file1 11', 'file1 12', 'file1 13', 'file1 14', 'file1 15',
|
|
'file1 16', 'file1 17', 'file1 18', 'file1 19', 'file1 20'];
|
|
const topOfFile2 = ['file2 1', 'file2 2', 'file2 3', 'file2 4', 'file2 5',
|
|
'file2 6', 'file2 7', 'file2 8', 'file2 9', 'file2 10',
|
|
'file2 11', 'file2 12', 'file2 13', 'file2 14', 'file2 15',
|
|
'file2 16', 'file2 17', 'file2 18', 'file2 19', 'file2 20'];
|
|
|
|
test('simple', t => {
|
|
const result = shell.head('test/resources/head/file1.txt');
|
|
t.falsy(shell.error());
|
|
t.is(result.code, 0);
|
|
t.is(result.toString(), topOfFile1.slice(0, 10).join('\n') + '\n');
|
|
});
|
|
|
|
test('multiple files', t => {
|
|
const result = shell.head('test/resources/head/file2.txt',
|
|
'test/resources/head/file1.txt');
|
|
t.falsy(shell.error());
|
|
t.is(result.code, 0);
|
|
t.is(result.toString(), topOfFile2
|
|
.slice(0, 10)
|
|
.concat(topOfFile1.slice(0, 10))
|
|
.join('\n') + '\n');
|
|
});
|
|
|
|
test('multiple files, array syntax', t => {
|
|
const result = shell.head(['test/resources/head/file2.txt',
|
|
'test/resources/head/file1.txt']);
|
|
t.falsy(shell.error());
|
|
t.is(result.code, 0);
|
|
t.is(result.toString(), topOfFile2
|
|
.slice(0, 10)
|
|
.concat(topOfFile1.slice(0, 10))
|
|
.join('\n') + '\n');
|
|
});
|
|
|
|
test('reading more lines than are in the file (no trailing newline)', t => {
|
|
const result = shell.head('test/resources/file2', 'test/resources/file1');
|
|
t.falsy(shell.error());
|
|
t.is(result.code, 0);
|
|
t.is(result.toString(), 'test2\ntest1'); // these files only have one line (no \n)
|
|
});
|
|
|
|
test('reading more lines than are in the file (with trailing newline)', t => {
|
|
const result = shell.head('test/resources/head/shortfile2',
|
|
'test/resources/head/shortfile1');
|
|
t.falsy(shell.error());
|
|
t.is(result.code, 0);
|
|
t.is(result.toString(), 'short2\nshort1\n'); // these files only have one line (with \n)
|
|
});
|
|
|
|
test('Globbed file', t => {
|
|
const result = shell.head('test/resources/head/file?.txt');
|
|
t.falsy(shell.error());
|
|
t.is(result.code, 0);
|
|
t.is(result.toString(), topOfFile1
|
|
.slice(0, 10)
|
|
.concat(topOfFile2.slice(0, 10))
|
|
.join('\n') + '\n');
|
|
});
|
|
|
|
test("With '-n <num>' option", t => {
|
|
const result = shell.head('-n', 4, 'test/resources/head/file2.txt',
|
|
'test/resources/head/file1.txt');
|
|
t.falsy(shell.error());
|
|
t.is(result.code, 0);
|
|
t.is(result.toString(), topOfFile2
|
|
.slice(0, 4)
|
|
.concat(topOfFile1.slice(0, 4))
|
|
.join('\n') + '\n');
|
|
});
|
|
|
|
test("With '{-n: <num>}' option", t => {
|
|
const result = shell.head({ '-n': 4 }, 'test/resources/head/file2.txt',
|
|
'test/resources/head/file1.txt');
|
|
t.falsy(shell.error());
|
|
t.is(result.code, 0);
|
|
t.is(result.toString(), topOfFile2
|
|
.slice(0, 4)
|
|
.concat(topOfFile1.slice(0, 4))
|
|
.join('\n') + '\n');
|
|
});
|
|
|
|
test('negative values (-num) are the same as (numLines - num)', t => {
|
|
const result = shell.head('-n', -46, 'test/resources/head/file1.txt');
|
|
t.falsy(shell.error());
|
|
t.is(result.code, 0);
|
|
t.is(result.toString(), 'file1 1\nfile1 2\nfile1 3\nfile1 4\n');
|
|
});
|
|
|
|
test('right-hand side of a pipe', t => {
|
|
const result = shell.cat('test/resources/head/file1.txt').head();
|
|
t.falsy(shell.error());
|
|
t.is(result.code, 0);
|
|
t.is(result.toString(), topOfFile1.slice(0, 10).join('\n') + '\n');
|
|
});
|