%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/forge/takeaseat.eco-n-tech.co.uk/node_modules/@nodelib/fs.stat/src/providers/
Upload File :
Create Path :
Current File : //home/forge/takeaseat.eco-n-tech.co.uk/node_modules/@nodelib/fs.stat/src/providers/async.spec.ts

import * as assert from 'assert';
import * as fs from 'fs';

import * as sinon from 'sinon';

import { Stats } from '../../../fs.macchiato';
import Settings from '../settings';
import * as provider from './async';

describe('Providers → Async', () => {
	describe('.read', () => {
		it('should return lstat for non-symlink entry', (done) => {
			const lstat = sinon.stub().yields(null, new Stats()) as unknown as typeof fs.lstat;

			const settings = new Settings({
				fs: { lstat }
			});

			provider.read('filepath', settings, (error, stats) => {
				assert.strictEqual(error, null);
				assert.strictEqual(stats.ino, 0);
				done();
			});
		});

		it('should return lstat for symlink entry when the "followSymbolicLink" option is disabled', (done) => {
			const lstat = sinon.stub().yields(null, new Stats({ isSymbolicLink: true })) as unknown as typeof fs.lstat;

			const settings = new Settings({
				followSymbolicLink: false,
				fs: { lstat }
			});

			provider.read('filepath', settings, (error, stats) => {
				assert.strictEqual(error, null);
				assert.strictEqual(stats.ino, 0);
				done();
			});
		});

		it('should return stat for symlink entry', (done) => {
			const lstat = sinon.stub().yields(null, new Stats({ isSymbolicLink: true })) as unknown as typeof fs.lstat;
			const stat = sinon.stub().yields(null, new Stats({ ino: 1 })) as unknown as typeof fs.stat;

			const settings = new Settings({
				fs: { lstat, stat }
			});

			provider.read('filepath', settings, (error, stats) => {
				assert.strictEqual(error, null);
				assert.strictEqual(stats.ino, 1);
				done();
			});
		});

		it('should return marked stat for symlink entry when the "markSymbolicLink" option is enabled', (done) => {
			const lstat = sinon.stub().yields(null, new Stats({ isSymbolicLink: true })) as unknown as typeof fs.lstat;
			const stat = sinon.stub().yields(null, new Stats({ ino: 1 })) as unknown as typeof fs.stat;

			const settings = new Settings({
				fs: { lstat, stat },
				markSymbolicLink: true
			});

			provider.read('filepath', settings, (error, stats) => {
				assert.strictEqual(error, null);
				assert.strictEqual(stats.isSymbolicLink(), true);
				done();
			});
		});

		it('should return lstat for broken symlink entry when the "throwErrorOnBrokenSymbolicLink" option is disabled', (done) => {
			const lstat = sinon.stub().yields(null, new Stats({ isSymbolicLink: true })) as unknown as typeof fs.lstat;
			const stat = sinon.stub().yields(new Error()) as unknown as typeof fs.stat;

			const settings = new Settings({
				fs: { lstat, stat },
				throwErrorOnBrokenSymbolicLink: false
			});

			provider.read('filepath', settings, (error, stats) => {
				assert.strictEqual(error, null);
				assert.strictEqual(stats.ino, 0);
				done();
			});
		});

		it('should throw an error when symlink entry is broken', (done) => {
			const lstat = sinon.stub().yields(null, new Stats({ isSymbolicLink: true })) as unknown as typeof fs.lstat;
			const stat = sinon.stub().yields(new Error('broken')) as unknown as typeof fs.stat;

			const settings = new Settings({
				fs: { lstat, stat }
			});

			provider.read('filepath', settings, (error) => {
				assert.strictEqual(error.message, 'broken');
				done();
			});
		});
	});
});

Zerion Mini Shell 1.0