shelljs/test/head.js
Nate Fischer 2ee83ebf74 refactor(test): update AVA and refactor tests (#760)
This updates tests for `AVA` 19.0.0+.

`AVA` 0.18.0 has a breaking change which changes the current working directory
for tests. As a result, we need to change 'resources' -> 'test/resources' (and
 similar path changes).

`AVA` 0.19.0 has a breaking change that all tests must run at least one assert.
This breaking change was already resolved by #746, so no change was necessary in
this PR.

This updates to `AVA` 0.21.0, since there are no other breaking changes.
2017-08-11 11:03:13 -07:00

137 lines
4.2 KiB
JavaScript

import fs from 'fs';
import test from 'ava';
import shell from '..';
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(fs.statSync('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');
});