Huakun Shen e4d1441d73
Feature: support npm extension publish (#62)
* feat: npm package registry API

* refactor: move package registry files

* refactor: move jsr and npm api to a new package

* ci: add verify-package-export

* test: implement tests for npm package validation as kunkun extension

* chore: add missing dep for package-registry pkg

* feat: make provenance an optional input for npm validation function

* ci: add verify-package-export as dev dep to 2 packages that uses it

* feat: add rekor log API, and return commit from jsr & npm package in validation function

* feat: return github repo info from validation function of jsr and npm

* feat: extend ExtPublishMetadata to include optional GitHub repository details

* fix: eslint for ui package

* refactor: format desktop

* fix: eslint errors in desktop

* format: all code

* ci: add lint to CI

* feat: add more info to validation function returned from package-registry npm jsr

* pnpm lock

* feat: add 2 more variables to supabase extension metadata model

* format

* feat: add provenance card

* feat: add workflow path to ExtPublishMetadata and jsr/npm validation

* update provenance

* feat: make store extension and provenance more responsive

* chore: add globals to ui package

* fix: remove unnecessary any to fix eslint

* fix: svg sanitize

* chore: add @typescript-eslint/eslint-plugin to ui package to fix eslint

* fix: update eslint dep to fix error

* fix: try fixing eslint

* fix: update eslint configuration for improved compatibility

* chore: add globals package and update README for Discord invite

* fix: update eslint rules and upgrade typescript-eslint dependency

- Disabled additional eslint rules to resolve errors:
  - @typescript-eslint/no-unused-expressions
  - svelte/no-inner-declarations
- Upgraded typescript-eslint from version 8.19.1 to 8.20.0 for improved compatibility.

* update pnpm lock

---------

Co-authored-by: Huakun Shen <huaukun.shen@huakunshen.com>
2025-01-16 06:00:07 -05:00

81 lines
2.2 KiB
TypeScript

import { describe, expect, test } from "bun:test"
import { validateJsrPackageAsKunkunExtension } from "../index"
describe("Validate Jsr package as Kunkun extension", () => {
test("Package not signed by GitHub Actions", async () => {
expect(
(
await validateJsrPackageAsKunkunExtension({
jsrPackage: {
scope: "kunkun",
name: "api",
version: "0.0.47"
},
githubUsername: "kunkunsh"
})
).error
).toBe("JSR package is not signed by GitHub Actions")
})
test("Non-existent package", async () => {
expect(
(
await validateJsrPackageAsKunkunExtension({
jsrPackage: {
scope: "kunkun",
name: "non-existent-package",
version: "0.0.47"
},
githubUsername: "kunkunsh"
})
).error
).toBe("JSR package does not exist")
})
test("Package not linked to a GitHub repository", async () => {
expect(
(
await validateJsrPackageAsKunkunExtension({
jsrPackage: {
scope: "hk",
name: "tauri-plugin-network-api",
version: "2.0.3-beta.1"
},
githubUsername: "kunkunsh"
})
).error
).toBe("JSR package is not linked to a GitHub repository")
})
test("GitHub repository owner does not match JSR package owner", async () => {
const res = await validateJsrPackageAsKunkunExtension({
jsrPackage: {
scope: "kunkun",
name: "ext-image-processing",
version: "0.0.18"
},
githubUsername: "Huakun"
})
expect(res.error).toBe(
"You (Huakun) are not authorized to publish this package. Only kunkunsh or its organization members can publish it."
)
})
test("A valid extension package", async () => {
const res = await validateJsrPackageAsKunkunExtension({
jsrPackage: {
scope: "kunkun",
name: "ext-image-processing",
version: "0.0.18"
},
githubUsername: "HuakunShen"
})
expect(res.data).toBeDefined()
expect(res.data?.rekorLogIndex).toBe("161854127")
expect(res.data?.github.commit).toBe("4db8d65b5e3fa115da6e31bd945f5c610c4a21cb")
expect(res.data?.github.owner).toBe("kunkunsh")
expect(res.data?.github.repo).toBe("kunkun-ext-image-processing")
// expect(res.data?.github.githubActionInvocationId).toBe("48b7dff528bc6a175ce9ee99e6d8de0c718e70a0")
})
})