mirror of
https://github.com/DeterminateSystems/update-flake-lock.git
synced 2025-01-25 21:45:10 +01:00
Provide improved input handling
This commit is contained in:
parent
b5a9000c3f
commit
c16b76233e
6 changed files with 68 additions and 27 deletions
25
dist/index.js
vendored
25
dist/index.js
vendored
|
@ -94754,6 +94754,17 @@ function mungeDiagnosticEndpoint(inputUrl) {
|
|||
// EXTERNAL MODULE: external "fs"
|
||||
var external_fs_ = __nccwpck_require__(7147);
|
||||
;// CONCATENATED MODULE: ./dist/index.js
|
||||
// src/inputs.ts
|
||||
function determineFlakeDirectories(input) {
|
||||
const sepChar = /\s+/;
|
||||
const trimmed = input.trim();
|
||||
if (trimmed === "") {
|
||||
return [];
|
||||
} else {
|
||||
return trimmed.split(sepChar).map((s) => s.trim());
|
||||
}
|
||||
}
|
||||
|
||||
// src/nix.ts
|
||||
function makeNixCommandArgs(nixOptions, flakeInputs, commitMessage) {
|
||||
const flakeInputFlags = flakeInputs.flatMap((input) => [
|
||||
|
@ -94781,6 +94792,12 @@ var UpdateFlakeLockAction = class extends DetSysAction {
|
|||
this.flakeInputs = inputs_exports.getArrayOfStrings("inputs", "space");
|
||||
this.nixOptions = inputs_exports.getArrayOfStrings("nix-options", "space");
|
||||
this.pathToFlakeDir = inputs_exports.getStringOrNull("path-to-flake-dir");
|
||||
const flakeDirsInput = inputs_exports.getStringOrNull("flake-dirs");
|
||||
if (flakeDirsInput !== null) {
|
||||
this.flakeDirs = determineFlakeDirectories(flakeDirsInput);
|
||||
} else {
|
||||
this.flakeDirs = null;
|
||||
}
|
||||
this.validateInputs();
|
||||
}
|
||||
async main() {
|
||||
|
@ -94789,14 +94806,6 @@ var UpdateFlakeLockAction = class extends DetSysAction {
|
|||
// No post phase
|
||||
async post() {
|
||||
}
|
||||
get flakeDirs() {
|
||||
const flakeDirs = inputs_exports.getStringOrNull("flake-dirs");
|
||||
if (flakeDirs !== null) {
|
||||
return flakeDirs.trim().split(" ");
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
async updateFlakeLock() {
|
||||
if (this.flakeDirs !== null && this.flakeDirs.length > 0) {
|
||||
core.debug(
|
||||
|
|
2
dist/index.js.map
vendored
2
dist/index.js.map
vendored
File diff suppressed because one or more lines are too long
|
@ -12,6 +12,7 @@
|
|||
"lint": "eslint src/**/*.ts --ignore-pattern *.test.ts",
|
||||
"package": "ncc build",
|
||||
"test": "vitest --watch false",
|
||||
"test-dev": "vitest",
|
||||
"all": "pnpm run format && pnpm run lint && pnpm run build && pnpm run package"
|
||||
},
|
||||
"repository": {
|
||||
|
|
18
src/index.ts
18
src/index.ts
|
@ -1,3 +1,4 @@
|
|||
import { determineFlakeDirectories } from "./inputs.js";
|
||||
import { makeNixCommandArgs } from "./nix.js";
|
||||
import * as actionsCore from "@actions/core";
|
||||
import * as actionsExec from "@actions/exec";
|
||||
|
@ -11,6 +12,7 @@ class UpdateFlakeLockAction extends DetSysAction {
|
|||
private nixOptions: string[];
|
||||
private flakeInputs: string[];
|
||||
private pathToFlakeDir: string | null;
|
||||
private flakeDirs: string[] | null;
|
||||
|
||||
constructor() {
|
||||
super({
|
||||
|
@ -24,6 +26,13 @@ class UpdateFlakeLockAction extends DetSysAction {
|
|||
this.nixOptions = inputs.getArrayOfStrings("nix-options", "space");
|
||||
this.pathToFlakeDir = inputs.getStringOrNull("path-to-flake-dir");
|
||||
|
||||
const flakeDirsInput = inputs.getStringOrNull("flake-dirs");
|
||||
if (flakeDirsInput !== null) {
|
||||
this.flakeDirs = determineFlakeDirectories(flakeDirsInput);
|
||||
} else {
|
||||
this.flakeDirs = null;
|
||||
}
|
||||
|
||||
this.validateInputs();
|
||||
}
|
||||
|
||||
|
@ -34,15 +43,6 @@ class UpdateFlakeLockAction extends DetSysAction {
|
|||
// No post phase
|
||||
async post(): Promise<void> {}
|
||||
|
||||
private get flakeDirs(): string[] | null {
|
||||
const flakeDirs = inputs.getStringOrNull("flake-dirs");
|
||||
if (flakeDirs !== null) {
|
||||
return flakeDirs.trim().split(" ");
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
async updateFlakeLock(): Promise<void> {
|
||||
if (this.flakeDirs !== null && this.flakeDirs.length > 0) {
|
||||
actionsCore.debug(
|
||||
|
|
10
src/inputs.ts
Normal file
10
src/inputs.ts
Normal file
|
@ -0,0 +1,10 @@
|
|||
// Helper function for nullable input fields into an array of strings
|
||||
export function determineFlakeDirectories(input: string): string[] {
|
||||
const sepChar = /\s+/;
|
||||
const trimmed = input.trim();
|
||||
if (trimmed === "") {
|
||||
return [];
|
||||
} else {
|
||||
return trimmed.split(sepChar).map((s: string) => s.trim());
|
||||
}
|
||||
}
|
|
@ -1,16 +1,17 @@
|
|||
import { determineFlakeDirectories } from "./inputs.js";
|
||||
import { makeNixCommandArgs } from "./nix.js";
|
||||
import { expect, test } from "vitest";
|
||||
|
||||
type TestCase = {
|
||||
inputs: {
|
||||
nixOptions: string[];
|
||||
flakeInputs: string[];
|
||||
commitMessage: string;
|
||||
};
|
||||
expected: string[];
|
||||
};
|
||||
|
||||
test("Nix command arguments", () => {
|
||||
type TestCase = {
|
||||
inputs: {
|
||||
nixOptions: string[];
|
||||
flakeInputs: string[];
|
||||
commitMessage: string;
|
||||
};
|
||||
expected: string[];
|
||||
};
|
||||
|
||||
const testCases: TestCase[] = [
|
||||
{
|
||||
inputs: {
|
||||
|
@ -72,3 +73,23 @@ test("Nix command arguments", () => {
|
|||
expect(args).toStrictEqual(expected);
|
||||
});
|
||||
});
|
||||
|
||||
test("Flake directory parsing", () => {
|
||||
type TestCase = {
|
||||
input: string;
|
||||
outputs: string[];
|
||||
};
|
||||
|
||||
const testCases: TestCase[] = [
|
||||
{ input: "", outputs: [] },
|
||||
{ input: "one two three", outputs: ["one", "two", "three"] },
|
||||
{
|
||||
input: ` one two three `,
|
||||
outputs: ["one", "two", "three"],
|
||||
},
|
||||
];
|
||||
|
||||
testCases.forEach(({ input, outputs }) => {
|
||||
expect(determineFlakeDirectories(input)).toStrictEqual(outputs);
|
||||
});
|
||||
});
|
Loading…
Reference in a new issue