chore(gladys): format description.md
This commit is contained in:
parent
70b00b809e
commit
8eace9c01d
|
@ -1,5 +1,5 @@
|
||||||
import fs from "fs";
|
import fs from 'fs';
|
||||||
import jsyaml from "js-yaml";
|
import jsyaml from 'js-yaml';
|
||||||
|
|
||||||
interface AppConfig {
|
interface AppConfig {
|
||||||
id: string;
|
id: string;
|
||||||
|
@ -18,17 +18,11 @@ interface AppConfig {
|
||||||
available: boolean;
|
available: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
const networkExceptions = [
|
const networkExceptions = ['pihole', 'tailscale', 'homeassistant', 'plex', 'zerotier', 'gladys'];
|
||||||
"pihole",
|
|
||||||
"tailscale",
|
|
||||||
"homeassistant",
|
|
||||||
"plex",
|
|
||||||
"zerotier",
|
|
||||||
];
|
|
||||||
const getAppConfigs = (): AppConfig[] => {
|
const getAppConfigs = (): AppConfig[] => {
|
||||||
const apps: AppConfig[] = [];
|
const apps: AppConfig[] = [];
|
||||||
|
|
||||||
const appsDir = fs.readdirSync("./apps");
|
const appsDir = fs.readdirSync('./apps');
|
||||||
|
|
||||||
appsDir.forEach((app: string) => {
|
appsDir.forEach((app: string) => {
|
||||||
const path = `./apps/${app}/config.json`;
|
const path = `./apps/${app}/config.json`;
|
||||||
|
@ -42,7 +36,7 @@ const getAppConfigs = (): AppConfig[] => {
|
||||||
apps.push(config);
|
apps.push(config);
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.error("Error parsing config file", app);
|
console.error('Error parsing config file', app);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -50,14 +44,14 @@ const getAppConfigs = (): AppConfig[] => {
|
||||||
return apps;
|
return apps;
|
||||||
};
|
};
|
||||||
|
|
||||||
describe("App configs", () => {
|
describe('App configs', () => {
|
||||||
it("Get app config should return at least one app", () => {
|
it('Get app config should return at least one app', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
expect(apps.length).toBeGreaterThan(0);
|
expect(apps.length).toBeGreaterThan(0);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have an id", () => {
|
it('Each app should have an id', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
|
@ -65,7 +59,7 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a md description", () => {
|
it('Each app should have a md description', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
|
@ -81,7 +75,7 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have categories defined as an array", () => {
|
it('Each app should have categories defined as an array', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
|
@ -90,7 +84,7 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a name", () => {
|
it('Each app should have a name', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
|
@ -98,7 +92,7 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a description", () => {
|
it('Each app should have a description', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
|
@ -106,7 +100,7 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a port", () => {
|
it('Each app should have a port', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
|
@ -116,19 +110,19 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a different port", () => {
|
it('Each app should have a different port', () => {
|
||||||
const appConfigs = getAppConfigs();
|
const appConfigs = getAppConfigs();
|
||||||
const ports = appConfigs.map((app) => app.port);
|
const ports = appConfigs.map((app) => app.port);
|
||||||
expect(new Set(ports).size).toBe(appConfigs.length);
|
expect(new Set(ports).size).toBe(appConfigs.length);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a unique id", () => {
|
it('Each app should have a unique id', () => {
|
||||||
const appConfigs = getAppConfigs();
|
const appConfigs = getAppConfigs();
|
||||||
const ids = appConfigs.map((app) => app.id);
|
const ids = appConfigs.map((app) => app.id);
|
||||||
expect(new Set(ids).size).toBe(appConfigs.length);
|
expect(new Set(ids).size).toBe(appConfigs.length);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a version", () => {
|
it('Each app should have a version', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
|
@ -137,7 +131,7 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a docker-compose file beside it", () => {
|
it('Each app should have a docker-compose file beside it', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
|
@ -145,7 +139,7 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a metadata folder beside it", () => {
|
it('Each app should have a metadata folder beside it', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
|
@ -153,7 +147,7 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a file named logo.jpg in the metadata folder", () => {
|
it('Each app should have a file named logo.jpg in the metadata folder', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
|
@ -161,13 +155,11 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have a container name equals to its id", () => {
|
it('Each app should have a container name equals to its id', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
const dockerComposeFile = fs
|
const dockerComposeFile = fs.readFileSync(`./apps/${app.id}/docker-compose.yml`).toString();
|
||||||
.readFileSync(`./apps/${app.id}/docker-compose.yml`)
|
|
||||||
.toString();
|
|
||||||
|
|
||||||
const dockerCompose: any = jsyaml.load(dockerComposeFile);
|
const dockerCompose: any = jsyaml.load(dockerComposeFile);
|
||||||
|
|
||||||
|
@ -180,14 +172,12 @@ describe("App configs", () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Each app should have network tipi_main_network", () => {
|
it('Each app should have network tipi_main_network', () => {
|
||||||
const apps = getAppConfigs();
|
const apps = getAppConfigs();
|
||||||
|
|
||||||
apps.forEach((app) => {
|
apps.forEach((app) => {
|
||||||
if (!networkExceptions.includes(app.id)) {
|
if (!networkExceptions.includes(app.id)) {
|
||||||
const dockerComposeFile = fs
|
const dockerComposeFile = fs.readFileSync(`./apps/${app.id}/docker-compose.yml`).toString();
|
||||||
.readFileSync(`./apps/${app.id}/docker-compose.yml`)
|
|
||||||
.toString();
|
|
||||||
|
|
||||||
const dockerCompose: any = jsyaml.load(dockerComposeFile);
|
const dockerCompose: any = jsyaml.load(dockerComposeFile);
|
||||||
|
|
||||||
|
@ -198,9 +188,7 @@ describe("App configs", () => {
|
||||||
}
|
}
|
||||||
|
|
||||||
expect(dockerCompose.services[app.id].networks).toBeDefined();
|
expect(dockerCompose.services[app.id].networks).toBeDefined();
|
||||||
expect(dockerCompose.services[app.id].networks).toStrictEqual([
|
expect(dockerCompose.services[app.id].networks).toStrictEqual(['tipi_main_network']);
|
||||||
"tipi_main_network",
|
|
||||||
]);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
version: "3"
|
version: '3'
|
||||||
|
|
||||||
services:
|
services:
|
||||||
gladys:
|
gladys:
|
||||||
|
@ -26,5 +26,3 @@ services:
|
||||||
#traefik.http.routers.gladys.service: gladys
|
#traefik.http.routers.gladys.service: gladys
|
||||||
#traefik.http.routers.gladys.tls.certresolver: myresolver
|
#traefik.http.routers.gladys.tls.certresolver: myresolver
|
||||||
#traefik.http.services.gladys.loadbalancer.server.port: 8270
|
#traefik.http.services.gladys.loadbalancer.server.port: 8270
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
# [![](https://camo.githubusercontent.com/b344c2958123d48c50b994207ea6ed266b77c01646437bf3b607f14787cbedb8/68747470733a2f2f676c61647973617373697374616e742e636f6d2f656e2f696d672f65787465726e616c2f6769746875622d676c616479732d6c6f676f2e706e67)](https://camo.githubusercontent.com/b344c2958123d48c50b994207ea6ed266b77c01646437bf3b607f14787cbedb8/68747470733a2f2f676c61647973617373697374616e742e636f6d2f656e2f696d672f65787465726e616c2f6769746875622d676c616479732d6c6f676f2e706e67)
|
|
||||||
Gladys Assistant
|
Gladys Assistant
|
||||||
|
|
||||||
## [Read the Docs](https://gladysassistant.com/docs/)
|
## [Read the Docs](https://gladysassistant.com/docs/)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user