chore(gladys): format description.md

This commit is contained in:
Nicolas Meienberger 2023-04-03 23:25:19 +02:00
parent 70b00b809e
commit 8eace9c01d
3 changed files with 43 additions and 58 deletions

View File

@ -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",
]);
} }
}); });
}); });

View File

@ -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

View File

@ -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/)