"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const assert = require("assert");
const sinon = require("sinon");
const fs_macchiato_1 = require("../../../fs.macchiato");
const settings_1 = require("../settings");
const provider = require("./sync");
describe('Providers → Sync', () => {
    describe('.read', () => {
        it('should return lstat for non-symlink entry', () => {
            const lstatSync = sinon.stub().returns(new fs_macchiato_1.Stats());
            const settings = new settings_1.default({
                fs: { lstatSync }
            });
            const actual = provider.read('filepath', settings);
            assert.strictEqual(actual.ino, 0);
        });
        it('should return lstat for symlink entry when the "followSymbolicLink" option is disabled', () => {
            const lstatSync = sinon.stub().returns(new fs_macchiato_1.Stats({ isSymbolicLink: true }));
            const settings = new settings_1.default({
                followSymbolicLink: false,
                fs: { lstatSync }
            });
            const actual = provider.read('filepath', settings);
            assert.strictEqual(actual.ino, 0);
        });
        it('should return stat for symlink entry', () => {
            const lstatSync = sinon.stub().returns(new fs_macchiato_1.Stats({ isSymbolicLink: true }));
            const statSync = sinon.stub().returns(new fs_macchiato_1.Stats({ ino: 1 }));
            const settings = new settings_1.default({
                fs: { lstatSync, statSync }
            });
            const actual = provider.read('filepath', settings);
            assert.strictEqual(actual.ino, 1);
        });
        it('should return marked stat for symlink entry when the "markSymbolicLink" option is enabled', () => {
            const lstatSync = sinon.stub().returns(new fs_macchiato_1.Stats({ isSymbolicLink: true }));
            const statSync = sinon.stub().returns(new fs_macchiato_1.Stats({ ino: 1 }));
            const settings = new settings_1.default({
                markSymbolicLink: true,
                fs: { lstatSync, statSync }
            });
            const actual = provider.read('filepath', settings);
            assert.strictEqual(actual.isSymbolicLink(), true);
        });
        it('should return lstat for broken symlink entry when the "throwErrorOnBrokenSymbolicLink" option is disabled', () => {
            const lstatSync = sinon.stub().returns(new fs_macchiato_1.Stats({ isSymbolicLink: true }));
            const statSync = sinon.stub().throws(new Error('error'));
            const settings = new settings_1.default({
                fs: { lstatSync, statSync },
                throwErrorOnBrokenSymbolicLink: false
            });
            const actual = provider.read('filepath', settings);
            assert.strictEqual(actual.ino, 0);
        });
        it('should throw an error when symlink entry is broken', () => {
            const lstatSync = sinon.stub().returns(new fs_macchiato_1.Stats({ isSymbolicLink: true }));
            const statSync = sinon.stub().throws(new Error('broken'));
            const settings = new settings_1.default({
                fs: { lstatSync, statSync }
            });
            const expectedErrorMessageRe = /broken/;
            assert.throws(() => provider.read('filepath', settings), expectedErrorMessageRe);
        });
    });
});