You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
165 lines
5.3 KiB
TypeScript
165 lines
5.3 KiB
TypeScript
import { serve } from "bun";
|
|
import { describe, expect, it } from "bun:test";
|
|
import {
|
|
createJSONResponse,
|
|
findResourceInstance,
|
|
runTerraformInit,
|
|
runTerraformApply,
|
|
testRequiredVariables,
|
|
} from "../test";
|
|
|
|
describe("jfrog-token", async () => {
|
|
type TestVariables = {
|
|
agent_id: string;
|
|
jfrog_url: string;
|
|
artifactory_access_token: string;
|
|
package_managers: string;
|
|
|
|
token_description?: string;
|
|
check_license?: boolean;
|
|
refreshable?: boolean;
|
|
expires_in?: number;
|
|
username_field?: string;
|
|
jfrog_server_id?: string;
|
|
configure_code_server?: boolean;
|
|
};
|
|
|
|
await runTerraformInit(import.meta.dir);
|
|
|
|
// Run a fake JFrog server so the provider can initialize
|
|
// correctly. This saves us from having to make remote requests!
|
|
const fakeFrogHost = serve({
|
|
fetch: (req) => {
|
|
const url = new URL(req.url);
|
|
// See https://jfrog.com/help/r/jfrog-rest-apis/license-information
|
|
if (url.pathname === "/artifactory/api/system/license")
|
|
return createJSONResponse({
|
|
type: "Commercial",
|
|
licensedTo: "JFrog inc.",
|
|
validThrough: "May 15, 2036",
|
|
});
|
|
if (url.pathname === "/access/api/v1/tokens")
|
|
return createJSONResponse({
|
|
token_id: "xxx",
|
|
access_token: "xxx",
|
|
scopes: "any",
|
|
});
|
|
return createJSONResponse({});
|
|
},
|
|
port: 0,
|
|
});
|
|
|
|
const fakeFrogApi = `${fakeFrogHost.hostname}:${fakeFrogHost.port}/artifactory/api`;
|
|
const fakeFrogUrl = `http://${fakeFrogHost.hostname}:${fakeFrogHost.port}`;
|
|
const user = "default";
|
|
const token = "xxx";
|
|
|
|
it("can run apply with required variables", async () => {
|
|
testRequiredVariables<TestVariables>(import.meta.dir, {
|
|
agent_id: "some-agent-id",
|
|
jfrog_url: fakeFrogUrl,
|
|
artifactory_access_token: "XXXX",
|
|
package_managers: "{}",
|
|
});
|
|
});
|
|
|
|
it("generates an npmrc with scoped repos", async () => {
|
|
const state = await runTerraformApply<TestVariables>(import.meta.dir, {
|
|
agent_id: "some-agent-id",
|
|
jfrog_url: fakeFrogUrl,
|
|
artifactory_access_token: "XXXX",
|
|
package_managers: JSON.stringify({
|
|
npm: ["global", "@foo:foo", "@bar:bar"],
|
|
}),
|
|
});
|
|
const coderScript = findResourceInstance(state, "coder_script");
|
|
const npmrcStanza = `cat << EOF > ~/.npmrc
|
|
email=${user}@example.com
|
|
registry=http://${fakeFrogApi}/npm/global
|
|
//${fakeFrogApi}/npm/global/:_authToken=xxx
|
|
@foo:registry=http://${fakeFrogApi}/npm/foo
|
|
//${fakeFrogApi}/npm/foo/:_authToken=xxx
|
|
@bar:registry=http://${fakeFrogApi}/npm/bar
|
|
//${fakeFrogApi}/npm/bar/:_authToken=xxx
|
|
|
|
EOF`;
|
|
expect(coderScript.script).toContain(npmrcStanza);
|
|
expect(coderScript.script).toContain(
|
|
'jf npmc --global --repo-resolve "global"',
|
|
);
|
|
expect(coderScript.script).toContain(
|
|
'if [ -z "YES" ]; then\n not_configured npm',
|
|
);
|
|
});
|
|
|
|
it("generates a pip config with extra-indexes", async () => {
|
|
const state = await runTerraformApply<TestVariables>(import.meta.dir, {
|
|
agent_id: "some-agent-id",
|
|
jfrog_url: fakeFrogUrl,
|
|
artifactory_access_token: "XXXX",
|
|
package_managers: JSON.stringify({
|
|
pypi: ["global", "foo", "bar"],
|
|
}),
|
|
});
|
|
const coderScript = findResourceInstance(state, "coder_script");
|
|
const pipStanza = `cat << EOF > ~/.pip/pip.conf
|
|
[global]
|
|
index-url = https://${user}:${token}@${fakeFrogApi}/pypi/global/simple
|
|
extra-index-url =
|
|
https://${user}:${token}@${fakeFrogApi}/pypi/foo/simple
|
|
https://${user}:${token}@${fakeFrogApi}/pypi/bar/simple
|
|
|
|
EOF`;
|
|
expect(coderScript.script).toContain(pipStanza);
|
|
expect(coderScript.script).toContain(
|
|
'jf pipc --global --repo-resolve "global"',
|
|
);
|
|
expect(coderScript.script).toContain(
|
|
'if [ -z "YES" ]; then\n not_configured pypi',
|
|
);
|
|
});
|
|
|
|
it("registers multiple docker repos", async () => {
|
|
const state = await runTerraformApply<TestVariables>(import.meta.dir, {
|
|
agent_id: "some-agent-id",
|
|
jfrog_url: fakeFrogUrl,
|
|
artifactory_access_token: "XXXX",
|
|
package_managers: JSON.stringify({
|
|
docker: ["foo.jfrog.io", "bar.jfrog.io", "baz.jfrog.io"],
|
|
}),
|
|
});
|
|
const coderScript = findResourceInstance(state, "coder_script");
|
|
const dockerStanza = ["foo", "bar", "baz"]
|
|
.map((r) => `register_docker "${r}.jfrog.io"`)
|
|
.join("\n");
|
|
expect(coderScript.script).toContain(dockerStanza);
|
|
expect(coderScript.script).toContain(
|
|
'if [ -z "YES" ]; then\n not_configured docker',
|
|
);
|
|
});
|
|
|
|
it("sets goproxy with multiple repos", async () => {
|
|
const state = await runTerraformApply<TestVariables>(import.meta.dir, {
|
|
agent_id: "some-agent-id",
|
|
jfrog_url: fakeFrogUrl,
|
|
artifactory_access_token: "XXXX",
|
|
package_managers: JSON.stringify({
|
|
go: ["foo", "bar", "baz"],
|
|
}),
|
|
});
|
|
const proxyEnv = findResourceInstance(state, "coder_env", "goproxy");
|
|
const proxies = ["foo", "bar", "baz"]
|
|
.map((r) => `https://${user}:${token}@${fakeFrogApi}/go/${r}`)
|
|
.join(",");
|
|
expect(proxyEnv.value).toEqual(proxies);
|
|
|
|
const coderScript = findResourceInstance(state, "coder_script");
|
|
expect(coderScript.script).toContain(
|
|
'jf goc --global --repo-resolve "foo"',
|
|
);
|
|
expect(coderScript.script).toContain(
|
|
'if [ -z "YES" ]; then\n not_configured go',
|
|
);
|
|
});
|
|
});
|