[babel-cli] Don't fail when chmod throws an error (#12846)
Co-authored-by: Nicolò Ribaudo <nicolo.ribaudo@gmail.com> Co-authored-by: Federico Ciardi <fed.ciardi@gmail.com>
This commit is contained in:
parent
c294de3529
commit
5bec993b7b
@ -6,7 +6,11 @@ import path from "path";
|
|||||||
import fs from "fs";
|
import fs from "fs";
|
||||||
|
|
||||||
export function chmod(src: string, dest: string): void {
|
export function chmod(src: string, dest: string): void {
|
||||||
fs.chmodSync(dest, fs.statSync(src).mode);
|
try {
|
||||||
|
fs.chmodSync(dest, fs.statSync(src).mode);
|
||||||
|
} catch (err) {
|
||||||
|
console.warn(`Cannot change permissions of ${dest}`);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
type ReaddirFilter = (filename: string) => boolean;
|
type ReaddirFilter = (filename: string) => boolean;
|
||||||
|
|||||||
@ -7,6 +7,7 @@ const escapeRegExp = require("lodash/escapeRegExp");
|
|||||||
const merge = require("lodash/merge");
|
const merge = require("lodash/merge");
|
||||||
const path = require("path");
|
const path = require("path");
|
||||||
const fs = require("fs");
|
const fs = require("fs");
|
||||||
|
const { chmod } = require("../lib/babel/util");
|
||||||
|
|
||||||
const fixtureLoc = path.join(__dirname, "fixtures");
|
const fixtureLoc = path.join(__dirname, "fixtures");
|
||||||
const tmpLoc = path.join(__dirname, "tmp");
|
const tmpLoc = path.join(__dirname, "tmp");
|
||||||
@ -269,3 +270,15 @@ fs.readdirSync(fixtureLoc).forEach(function (binName) {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe("util.js", () => {
|
||||||
|
describe("chmod", () => {
|
||||||
|
it("should warn the user if chmod fails", () => {
|
||||||
|
const spyConsoleWarn = jest.spyOn(console, "warn");
|
||||||
|
// should expect a string as first argument
|
||||||
|
chmod(100, "file.js");
|
||||||
|
expect(spyConsoleWarn).toHaveBeenCalledTimes(1);
|
||||||
|
spyConsoleWarn.mockRestore();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user