mirror of
				https://github.com/actions/cache.git
				synced 2025-11-04 13:29:10 +08:00 
			
		
		
		
	Sort inputs and remove whitespaces after exclamation at the beginning of lines
This commit is contained in:
		@@ -215,6 +215,36 @@ test("getInputAsArray handles empty lines correctly", () => {
 | 
			
		||||
    expect(actionUtils.getInputAsArray("foo")).toEqual(["bar", "baz"]);
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
test("getInputAsArray sorts files correctly", () => {
 | 
			
		||||
    testUtils.setInput("foo", "bar\n!baz\nwaldo\nqux\nquux\ncorge\ngrault\ngarply");
 | 
			
		||||
    expect(actionUtils.getInputAsArray("foo")).toEqual([
 | 
			
		||||
        "!baz",
 | 
			
		||||
        "bar",
 | 
			
		||||
        "corge",
 | 
			
		||||
        "garply",
 | 
			
		||||
        "grault",
 | 
			
		||||
        "quux",
 | 
			
		||||
        "qux",
 | 
			
		||||
        "waldo"
 | 
			
		||||
    ]);
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
test("getInputAsArray removes spaces after ! at the beginning", () => {
 | 
			
		||||
    testUtils.setInput(
 | 
			
		||||
        "foo",
 | 
			
		||||
        "!   bar\n!  baz\n! qux\n!quux\ncorge\ngrault! garply\n!\r\t waldo"
 | 
			
		||||
    );
 | 
			
		||||
    expect(actionUtils.getInputAsArray("foo")).toEqual([
 | 
			
		||||
        "!bar",
 | 
			
		||||
        "!baz",
 | 
			
		||||
        "!quux",
 | 
			
		||||
        "!qux",
 | 
			
		||||
        "!waldo",
 | 
			
		||||
        "corge",
 | 
			
		||||
        "grault! garply"
 | 
			
		||||
    ]);
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
test("getInputAsInt returns undefined if input not set", () => {
 | 
			
		||||
    expect(actionUtils.getInputAsInt("undefined")).toBeUndefined();
 | 
			
		||||
});
 | 
			
		||||
 
 | 
			
		||||
@@ -147,7 +147,7 @@ test("restore with no key", async () => {
 | 
			
		||||
test("restore with too many keys should fail", async () => {
 | 
			
		||||
    const path = "node_modules";
 | 
			
		||||
    const key = "node-test";
 | 
			
		||||
    const restoreKeys = [...Array(20).keys()].map(x => x.toString());
 | 
			
		||||
    const restoreKeys = [...Array(20).keys()].map(x => x.toString()).sort();
 | 
			
		||||
    testUtils.setInputs({
 | 
			
		||||
        path: path,
 | 
			
		||||
        key,
 | 
			
		||||
 
 | 
			
		||||
@@ -61,8 +61,9 @@ export function getInputAsArray(
 | 
			
		||||
    return core
 | 
			
		||||
        .getInput(name, options)
 | 
			
		||||
        .split("\n")
 | 
			
		||||
        .map(s => s.trim())
 | 
			
		||||
        .filter(x => x !== "");
 | 
			
		||||
        .map(s => s.replace(/^\!\s+/, '!').trim())
 | 
			
		||||
        .filter(x => x !== "")
 | 
			
		||||
        .sort();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function getInputAsInt(
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user