1
1
mirror of https://github.com/theoludwig/programming-challenges.git synced 2024-12-08 00:45:29 +01:00

build(deps): update latest

This commit is contained in:
Théo LUDWIG 2024-11-18 01:04:51 +01:00
parent c807aeaf3f
commit 9a187deaef
Signed by: theoludwig
GPG Key ID: ADFE5A563D718F3B
21 changed files with 2152 additions and 3513 deletions

View File

@ -1 +0,0 @@
{ "extends": ["@commitlint/config-conventional"] }

View File

@ -1,18 +0,0 @@
{
"extends": ["conventions"],
"plugins": ["import", "unicorn"],
"parserOptions": {
"project": "./tsconfig.json"
},
"rules": {
"import/extensions": ["error", "always"],
"unicorn/prevent-abbreviations": "error",
"unicorn/prefer-node-protocol": "error"
},
"overrides": [
{
"files": ["*.ts", "*.tsx"],
"parser": "@typescript-eslint/parser"
}
]
}

View File

@ -11,7 +11,7 @@ jobs:
runs-on: "ubuntu-latest" runs-on: "ubuntu-latest"
timeout-minutes: 30 timeout-minutes: 30
steps: steps:
- uses: "actions/checkout@v4.1.1" - uses: "actions/checkout@v4.2.2"
with: with:
fetch-depth: 0 fetch-depth: 0
@ -21,7 +21,7 @@ jobs:
SKIP_LOGIN: true SKIP_LOGIN: true
- name: "Setup Node.js" - name: "Setup Node.js"
uses: "actions/setup-node@v4.0.1" uses: "actions/setup-node@v4.1.0"
with: with:
node-version: "lts/*" node-version: "lts/*"
cache: "npm" cache: "npm"

View File

@ -10,10 +10,10 @@ jobs:
lint: lint:
runs-on: "ubuntu-latest" runs-on: "ubuntu-latest"
steps: steps:
- uses: "actions/checkout@v4.1.1" - uses: "actions/checkout@v4.2.2"
- name: "Setup Node.js" - name: "Setup Node.js"
uses: "actions/setup-node@v4.0.1" uses: "actions/setup-node@v4.1.0"
with: with:
node-version: "lts/*" node-version: "lts/*"
cache: "npm" cache: "npm"
@ -21,7 +21,6 @@ jobs:
- name: "Install dependencies" - name: "Install dependencies"
run: "npm clean-install" run: "npm clean-install"
- run: 'npm run lint:commit -- --to "${{ github.sha }}"'
- run: "npm run lint:editorconfig" - run: "npm run lint:editorconfig"
- run: "npm run lint:markdown" - run: "npm run lint:markdown"
- run: "npm run lint:eslint" - run: "npm run lint:eslint"
@ -29,10 +28,10 @@ jobs:
build: build:
runs-on: "ubuntu-latest" runs-on: "ubuntu-latest"
steps: steps:
- uses: "actions/checkout@v4.1.1" - uses: "actions/checkout@v4.2.2"
- name: "Setup Node.js" - name: "Setup Node.js"
uses: "actions/setup-node@v4.0.1" uses: "actions/setup-node@v4.1.0"
with: with:
node-version: "lts/*" node-version: "lts/*"
cache: "npm" cache: "npm"
@ -43,12 +42,12 @@ jobs:
- name: "Build" - name: "Build"
run: "npm run build" run: "npm run build"
- run: "npm run build:typescript" - run: "npm run lint:typescript"
test: test:
runs-on: "ubuntu-latest" runs-on: "ubuntu-latest"
steps: steps:
- uses: "actions/checkout@v4.1.1" - uses: "actions/checkout@v4.2.2"
- name: "Setup Docker" - name: "Setup Docker"
uses: "actions-hub/docker/cli@master" uses: "actions-hub/docker/cli@master"
@ -56,7 +55,7 @@ jobs:
SKIP_LOGIN: true SKIP_LOGIN: true
- name: "Setup Node.js" - name: "Setup Node.js"
uses: "actions/setup-node@v4.0.1" uses: "actions/setup-node@v4.1.0"
with: with:
node-version: "lts/*" node-version: "lts/*"
cache: "npm" cache: "npm"

View File

@ -48,7 +48,7 @@ Gitpod will automatically setup an environment for you.
#### Prerequisites #### Prerequisites
- [Node.js](https://nodejs.org/) >= 20.0.0 - [Node.js](https://nodejs.org/) >= 20.11.0
- [npm](https://npmjs.com/) >= 10.0.0 - [npm](https://npmjs.com/) >= 10.0.0
- [Docker](https://www.docker.com/) - [Docker](https://www.docker.com/)

View File

@ -47,7 +47,7 @@ export class Solution implements SolutionOptions {
challenge.path, challenge.path,
"solutions", "solutions",
programmingLanguageName, programmingLanguageName,
name, name
) )
this.temporaryFolder = new TemporaryFolder() this.temporaryFolder = new TemporaryFolder()
} }
@ -83,7 +83,7 @@ export class Solution implements SolutionOptions {
loader.succeed(chalk.bold.green("Success!")) loader.succeed(chalk.bold.green("Success!"))
SolutionTestsResult.printBenchmark(elapsedTimeMilliseconds) SolutionTestsResult.printBenchmark(elapsedTimeMilliseconds)
if (output) { if (output) {
console.log(`${chalk.bold("Output:")}`) console.log(chalk.bold("Output:"))
console.log(stdout) console.log(stdout)
} }
} catch (error: any) { } catch (error: any) {
@ -137,7 +137,7 @@ export class Solution implements SolutionOptions {
const languagesSolution = (await fs.promises.readdir(solutionsPath)).filter( const languagesSolution = (await fs.promises.readdir(solutionsPath)).filter(
(name) => { (name) => {
return name !== ".gitkeep" return name !== ".gitkeep"
}, }
) )
const paths: string[] = [] const paths: string[] = []
for (const language of languagesSolution) { for (const language of languagesSolution) {
@ -152,12 +152,12 @@ export class Solution implements SolutionOptions {
} }
static async getManyByProgrammingLanguages( static async getManyByProgrammingLanguages(
programmingLanguages?: string[], programmingLanguages?: string[]
): Promise<Solution[]> { ): Promise<Solution[]> {
const languages = const languages =
programmingLanguages ?? (await template.getProgrammingLanguages()) programmingLanguages ?? (await template.getProgrammingLanguages())
const challengesPath = fileURLToPath( const challengesPath = fileURLToPath(
new URL("../../challenges", import.meta.url), new URL("../../challenges", import.meta.url)
) )
const challenges = await fs.promises.readdir(challengesPath) const challenges = await fs.promises.readdir(challengesPath)
const paths: string[] = [] const paths: string[] = []

View File

@ -2,13 +2,11 @@ import path from "node:path"
import { fileURLToPath } from "node:url" import { fileURLToPath } from "node:url"
import fs from "node:fs" import fs from "node:fs"
import replaceInFileDefault from "replace-in-file" import { replaceInFile } from "replace-in-file"
import date from "date-and-time" import date from "date-and-time"
import { copyDirectory } from "../utils/copyDirectory.js" import { copyDirectory } from "../utils/copyDirectory.js"
const { replaceInFile } = replaceInFileDefault
const TEMPLATE_PATH = fileURLToPath(new URL("../../templates", import.meta.url)) const TEMPLATE_PATH = fileURLToPath(new URL("../../templates", import.meta.url))
const TEMPLATE_DOCKER_PATH = path.join(TEMPLATE_PATH, "docker") const TEMPLATE_DOCKER_PATH = path.join(TEMPLATE_PATH, "docker")
const TEMPLATE_CHALLENGE_PATH = path.join(TEMPLATE_PATH, "challenge") const TEMPLATE_CHALLENGE_PATH = path.join(TEMPLATE_PATH, "challenge")
@ -52,7 +50,7 @@ class Template {
} }
private async replaceInDestination( private async replaceInDestination(
options: ReplaceInDestinationOptions, options: ReplaceInDestinationOptions
): Promise<void> { ): Promise<void> {
const { name, description, destination } = options const { name, description, destination } = options
const readmePath = path.join(destination, "README.md") const readmePath = path.join(destination, "README.md")
@ -84,7 +82,7 @@ class Template {
} = options } = options
const templateLanguagePath = path.join( const templateLanguagePath = path.join(
TEMPLATE_SOLUTION_PATH, TEMPLATE_SOLUTION_PATH,
programmingLanguageName, programmingLanguageName
) )
await this.verifySupportedProgrammingLanguage(programmingLanguageName) await this.verifySupportedProgrammingLanguage(programmingLanguageName)
await fs.promises.mkdir(destination, { recursive: true }) await fs.promises.mkdir(destination, { recursive: true })
@ -115,7 +113,7 @@ class Template {
} }
public async verifySupportedProgrammingLanguage( public async verifySupportedProgrammingLanguage(
language: string, language: string
): Promise<void> { ): Promise<void> {
const languages = await this.getProgrammingLanguages() const languages = await this.getProgrammingLanguages()
if (!languages.includes(language)) { if (!languages.includes(language)) {

13
eslint.config.js Normal file
View File

@ -0,0 +1,13 @@
import typescriptESLint from "typescript-eslint"
import configConventions from "eslint-config-conventions"
export default typescriptESLint.config(...configConventions, {
files: ["**/*.ts", "**/*.tsx"],
languageOptions: {
parser: typescriptESLint.parser,
parserOptions: {
projectService: true,
tsconfigRootDir: import.meta.dirname,
},
},
})

5513
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -10,7 +10,7 @@
"url": "https://github.com/theoludwig/programming-challenges" "url": "https://github.com/theoludwig/programming-challenges"
}, },
"engines": { "engines": {
"node": ">=20.0.0", "node": ">=20.11.0",
"npm": ">=10.0.0" "npm": ">=10.0.0"
}, },
"main": "build/index.js", "main": "build/index.js",
@ -19,51 +19,48 @@
"start": "node --enable-source-maps build/index.js", "start": "node --enable-source-maps build/index.js",
"build": "swc ./cli --out-dir ./build --strip-leading-paths --delete-dir-on-start", "build": "swc ./cli --out-dir ./build --strip-leading-paths --delete-dir-on-start",
"build:dev": "swc ./cli --out-dir ./build --strip-leading-paths --delete-dir-on-start --watch", "build:dev": "swc ./cli --out-dir ./build --strip-leading-paths --delete-dir-on-start --watch",
"build:typescript": "tsc", "lint:typescript": "tsc --noEmit",
"lint:commit": "commitlint",
"lint:editorconfig": "editorconfig-checker", "lint:editorconfig": "editorconfig-checker",
"lint:markdown": "markdownlint-cli2", "lint:markdown": "markdownlint-cli2",
"lint:eslint": "eslint ./cli --max-warnings 0 --report-unused-disable-directives --ignore-path .gitignore", "lint:eslint": "eslint ./cli --max-warnings 0",
"test": "cross-env NODE_ENV=test node --enable-source-maps --test build/" "test": "cross-env NODE_ENV=test node --enable-source-maps --test \"build/**/*.test.js\""
}, },
"dependencies": { "dependencies": {
"chalk": "5.3.0", "chalk": "5.3.0",
"clipanion": "3.2.1", "clipanion": "3.2.1",
"date-and-time": "3.1.1", "date-and-time": "3.6.0",
"execa": "8.0.1", "execa": "9.5.1",
"log-symbols": "6.0.0", "log-symbols": "6.0.0",
"ora": "8.0.1", "ora": "8.1.1",
"replace-in-file": "7.1.0", "replace-in-file": "8.2.0",
"table": "6.8.1", "table": "6.8.2",
"typanion": "3.14.0", "typanion": "3.14.0",
"validate-npm-package-name": "5.0.0" "validate-npm-package-name": "6.0.0"
}, },
"devDependencies": { "devDependencies": {
"@commitlint/cli": "18.6.0", "@swc/cli": "0.5.0",
"@commitlint/config-conventional": "18.6.0", "@swc/core": "1.9.2",
"@swc/cli": "0.3.5", "@tsconfig/strictest": "2.0.5",
"@swc/core": "1.3.107",
"@tsconfig/strictest": "2.0.2",
"@types/mock-fs": "4.13.4", "@types/mock-fs": "4.13.4",
"@types/ms": "0.7.34", "@types/ms": "0.7.34",
"@types/node": "20.11.10", "@types/node": "22.9.0",
"@types/sinon": "17.0.3", "@types/sinon": "17.0.3",
"@types/validate-npm-package-name": "4.0.2", "@types/validate-npm-package-name": "4.0.2",
"@typescript-eslint/eslint-plugin": "6.20.0", "typescript-eslint": "8.14.0",
"@typescript-eslint/parser": "6.20.0",
"cross-env": "7.0.3", "cross-env": "7.0.3",
"editorconfig-checker": "5.1.2", "editorconfig-checker": "6.0.0",
"eslint": "8.56.0", "eslint": "9.15.0",
"eslint-config-conventions": "13.1.0", "eslint-config-conventions": "17.0.1",
"eslint-plugin-import": "2.29.1", "eslint-plugin-import-x": "4.4.2",
"eslint-plugin-promise": "6.1.1", "eslint-plugin-promise": "7.1.0",
"eslint-plugin-unicorn": "50.0.1", "eslint-plugin-unicorn": "56.0.0",
"get-stream": "8.0.1", "globals": "15.12.0",
"markdownlint-cli2": "0.12.1", "get-stream": "9.0.1",
"markdownlint-rule-relative-links": "2.2.0", "markdownlint-cli2": "0.15.0",
"mock-fs": "5.2.0", "markdownlint-rule-relative-links": "3.0.0",
"mock-fs": "5.4.1",
"ms": "2.1.3", "ms": "2.1.3",
"sinon": "17.0.1", "sinon": "19.0.2",
"typescript": "5.3.3" "typescript": "5.6.3"
} }
} }

View File

@ -1,4 +1,4 @@
FROM gcc:12.3.0-bookworm AS builder FROM gcc:12.4.0-bookworm AS builder
WORKDIR /usr/src/application WORKDIR /usr/src/application
COPY ./ ./ COPY ./ ./
RUN gcc ./*.c* -o solution -Wall -Wextra -Wfloat-equal -Wundef -Werror -std=c17 -pedantic -pedantic-errors -O3 RUN gcc ./*.c* -o solution -Wall -Wextra -Wfloat-equal -Wundef -Werror -std=c17 -pedantic -pedantic-errors -O3

View File

@ -1,4 +1,4 @@
FROM gcc:12.3.0-bookworm AS builder FROM gcc:12.4.0-bookworm AS builder
WORKDIR /usr/src/application WORKDIR /usr/src/application
COPY ./ ./ COPY ./ ./
RUN g++ ./*.cpp* -o solution -Wall -Wextra -Wfloat-equal -Wundef -Werror -std=c++17 -pedantic -pedantic-errors -O3 RUN g++ ./*.cpp* -o solution -Wall -Wextra -Wfloat-equal -Wundef -Werror -std=c++17 -pedantic -pedantic-errors -O3

View File

@ -1,4 +1,4 @@
FROM mono:6.12.0 FROM mono:6.12.0.182
WORKDIR /usr/src/application WORKDIR /usr/src/application
COPY ./ ./ COPY ./ ./
RUN mcs ./Solution.cs -out:Solution.exe RUN mcs ./Solution.cs -out:Solution.exe

View File

@ -1,4 +1,4 @@
FROM dart:3.2.5 AS builder FROM dart:3.5.4 AS builder
WORKDIR /usr/src/application WORKDIR /usr/src/application
COPY ./ ./ COPY ./ ./
RUN dart compile exe solution.dart -o solution RUN dart compile exe solution.dart -o solution

View File

@ -1,10 +1,10 @@
FROM openjdk:17 AS builder FROM openjdk:21 AS builder
WORKDIR /usr/src/application WORKDIR /usr/src/application
COPY ./ ./ COPY ./ ./
RUN javac Solution.java RUN javac Solution.java
RUN jar cfe solution.jar Solution *.class RUN jar cfe solution.jar Solution *.class
FROM gcr.io/distroless/java17-debian12:latest AS runner FROM gcr.io/distroless/java21-debian12:latest AS runner
WORKDIR /usr/src/application WORKDIR /usr/src/application
COPY --from=builder /usr/src/application/solution.jar ./ COPY --from=builder /usr/src/application/solution.jar ./
CMD ["./solution.jar"] CMD ["./solution.jar"]

View File

@ -1,4 +1,4 @@
FROM gcr.io/distroless/nodejs20-debian12:latest AS runner FROM gcr.io/distroless/nodejs22-debian12:latest AS runner
WORKDIR /usr/src/application WORKDIR /usr/src/application
COPY ./ ./ COPY ./ ./
CMD ["./solution.js"] CMD ["./solution.js"]

View File

@ -1,4 +1,4 @@
FROM pypy:3.10 FROM pypy:3.10-bookworm
WORKDIR /usr/src/application WORKDIR /usr/src/application
COPY ./ ./ COPY ./ ./
CMD ["python", "solution.py"] CMD ["python", "solution.py"]

View File

@ -1,4 +1,4 @@
FROM rust:1.75.0 AS builder FROM rust:1.82.0 AS builder
WORKDIR /usr/src/rust_application WORKDIR /usr/src/rust_application
# Cache dependencies # Cache dependencies

View File

@ -1,15 +1,15 @@
FROM node:20.11.0 AS builder-dependencies FROM node:22.11.0 AS builder-dependencies
WORKDIR /usr/src/application WORKDIR /usr/src/application
COPY ./package*.json ./ COPY ./package*.json ./
RUN npm install RUN npm install
FROM node:20.11.0 AS builder FROM node:22.11.0 AS builder
WORKDIR /usr/src/application WORKDIR /usr/src/application
COPY --from=builder-dependencies /usr/src/application/node_modules ./node_modules COPY --from=builder-dependencies /usr/src/application/node_modules ./node_modules
COPY ./ ./ COPY ./ ./
RUN npm run build RUN npm run build
FROM gcr.io/distroless/nodejs20-debian12:latest AS runner FROM gcr.io/distroless/nodejs22-debian12:latest AS runner
WORKDIR /usr/src/application WORKDIR /usr/src/application
ENV NODE_ENV=production ENV NODE_ENV=production
COPY --from=builder /usr/src/application/package.json ./package.json COPY --from=builder /usr/src/application/package.json ./package.json

View File

@ -4,7 +4,7 @@
"build": "tsc" "build": "tsc"
}, },
"devDependencies": { "devDependencies": {
"@types/node": "20.6.2", "@types/node": "22.9.0",
"typescript": "5.2.2" "typescript": "5.6.3"
} }
} }