mirror of
https://github.com/DeterminateSystems/update-flake-lock.git
synced 2025-01-11 06:42:41 +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"
|
// EXTERNAL MODULE: external "fs"
|
||||||
var external_fs_ = __nccwpck_require__(7147);
|
var external_fs_ = __nccwpck_require__(7147);
|
||||||
;// CONCATENATED MODULE: ./dist/index.js
|
;// 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
|
// src/nix.ts
|
||||||
function makeNixCommandArgs(nixOptions, flakeInputs, commitMessage) {
|
function makeNixCommandArgs(nixOptions, flakeInputs, commitMessage) {
|
||||||
const flakeInputFlags = flakeInputs.flatMap((input) => [
|
const flakeInputFlags = flakeInputs.flatMap((input) => [
|
||||||
|
@ -94781,6 +94792,12 @@ var UpdateFlakeLockAction = class extends DetSysAction {
|
||||||
this.flakeInputs = inputs_exports.getArrayOfStrings("inputs", "space");
|
this.flakeInputs = inputs_exports.getArrayOfStrings("inputs", "space");
|
||||||
this.nixOptions = inputs_exports.getArrayOfStrings("nix-options", "space");
|
this.nixOptions = inputs_exports.getArrayOfStrings("nix-options", "space");
|
||||||
this.pathToFlakeDir = inputs_exports.getStringOrNull("path-to-flake-dir");
|
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();
|
this.validateInputs();
|
||||||
}
|
}
|
||||||
async main() {
|
async main() {
|
||||||
|
@ -94789,14 +94806,6 @@ var UpdateFlakeLockAction = class extends DetSysAction {
|
||||||
// No post phase
|
// No post phase
|
||||||
async post() {
|
async post() {
|
||||||
}
|
}
|
||||||
get flakeDirs() {
|
|
||||||
const flakeDirs = inputs_exports.getStringOrNull("flake-dirs");
|
|
||||||
if (flakeDirs !== null) {
|
|
||||||
return flakeDirs.trim().split(" ");
|
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
async updateFlakeLock() {
|
async updateFlakeLock() {
|
||||||
if (this.flakeDirs !== null && this.flakeDirs.length > 0) {
|
if (this.flakeDirs !== null && this.flakeDirs.length > 0) {
|
||||||
core.debug(
|
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",
|
"lint": "eslint src/**/*.ts --ignore-pattern *.test.ts",
|
||||||
"package": "ncc build",
|
"package": "ncc build",
|
||||||
"test": "vitest --watch false",
|
"test": "vitest --watch false",
|
||||||
|
"test-dev": "vitest",
|
||||||
"all": "pnpm run format && pnpm run lint && pnpm run build && pnpm run package"
|
"all": "pnpm run format && pnpm run lint && pnpm run build && pnpm run package"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
|
|
18
src/index.ts
18
src/index.ts
|
@ -1,3 +1,4 @@
|
||||||
|
import { determineFlakeDirectories } from "./inputs.js";
|
||||||
import { makeNixCommandArgs } from "./nix.js";
|
import { makeNixCommandArgs } from "./nix.js";
|
||||||
import * as actionsCore from "@actions/core";
|
import * as actionsCore from "@actions/core";
|
||||||
import * as actionsExec from "@actions/exec";
|
import * as actionsExec from "@actions/exec";
|
||||||
|
@ -11,6 +12,7 @@ class UpdateFlakeLockAction extends DetSysAction {
|
||||||
private nixOptions: string[];
|
private nixOptions: string[];
|
||||||
private flakeInputs: string[];
|
private flakeInputs: string[];
|
||||||
private pathToFlakeDir: string | null;
|
private pathToFlakeDir: string | null;
|
||||||
|
private flakeDirs: string[] | null;
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
super({
|
super({
|
||||||
|
@ -24,6 +26,13 @@ class UpdateFlakeLockAction extends DetSysAction {
|
||||||
this.nixOptions = inputs.getArrayOfStrings("nix-options", "space");
|
this.nixOptions = inputs.getArrayOfStrings("nix-options", "space");
|
||||||
this.pathToFlakeDir = inputs.getStringOrNull("path-to-flake-dir");
|
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();
|
this.validateInputs();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,15 +43,6 @@ class UpdateFlakeLockAction extends DetSysAction {
|
||||||
// No post phase
|
// No post phase
|
||||||
async post(): Promise<void> {}
|
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> {
|
async updateFlakeLock(): Promise<void> {
|
||||||
if (this.flakeDirs !== null && this.flakeDirs.length > 0) {
|
if (this.flakeDirs !== null && this.flakeDirs.length > 0) {
|
||||||
actionsCore.debug(
|
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,6 +1,8 @@
|
||||||
|
import { determineFlakeDirectories } from "./inputs.js";
|
||||||
import { makeNixCommandArgs } from "./nix.js";
|
import { makeNixCommandArgs } from "./nix.js";
|
||||||
import { expect, test } from "vitest";
|
import { expect, test } from "vitest";
|
||||||
|
|
||||||
|
test("Nix command arguments", () => {
|
||||||
type TestCase = {
|
type TestCase = {
|
||||||
inputs: {
|
inputs: {
|
||||||
nixOptions: string[];
|
nixOptions: string[];
|
||||||
|
@ -10,7 +12,6 @@ type TestCase = {
|
||||||
expected: string[];
|
expected: string[];
|
||||||
};
|
};
|
||||||
|
|
||||||
test("Nix command arguments", () => {
|
|
||||||
const testCases: TestCase[] = [
|
const testCases: TestCase[] = [
|
||||||
{
|
{
|
||||||
inputs: {
|
inputs: {
|
||||||
|
@ -72,3 +73,23 @@ test("Nix command arguments", () => {
|
||||||
expect(args).toStrictEqual(expected);
|
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