mirror of
https://github.com/iptv-org/database.git
synced 2025-05-10 03:30:01 -04:00
122 lines
5.1 KiB
TypeScript
122 lines
5.1 KiB
TypeScript
import { execSync } from 'child_process'
|
|
import os from 'os'
|
|
|
|
type ExecError = {
|
|
status: number
|
|
stdout: string
|
|
}
|
|
|
|
describe('db:validate', () => {
|
|
it('shows an error if the number of columns in a row is incorrect', () => {
|
|
let ENV_VAR = 'DATA_DIR=tests/__data__/input/db/validate/wrong_num_cols'
|
|
if (os.platform() === 'win32') {
|
|
ENV_VAR = 'SET "DATA_DIR=tests/__data__/input/db/validate/wrong_num_cols" &&'
|
|
}
|
|
const cmd = `${ENV_VAR} npm run db:validate`
|
|
try {
|
|
const stdout = execSync(cmd, { encoding: 'utf8' })
|
|
if (process.env.DEBUG === 'true') console.log(cmd, stdout)
|
|
process.exit(1)
|
|
} catch (error) {
|
|
if (process.env.DEBUG === 'true') console.log(cmd, (error as ExecError).stdout)
|
|
expect((error as ExecError).status).toBe(1)
|
|
expect((error as ExecError).stdout).toContain('row has the wrong number of columns')
|
|
}
|
|
})
|
|
|
|
it('shows an error if one of the lines ends with an invalid character', () => {
|
|
let ENV_VAR = 'DATA_DIR=tests/__data__/input/db/validate/invalid_line_ending'
|
|
if (os.platform() === 'win32') {
|
|
ENV_VAR = 'SET "DATA_DIR=tests/__data__/input/db/validate/invalid_line_ending" &&'
|
|
}
|
|
const cmd = `${ENV_VAR} npm run db:validate`
|
|
try {
|
|
const stdout = execSync(cmd, { encoding: 'utf8' })
|
|
if (process.env.DEBUG === 'true') console.log(cmd, stdout)
|
|
process.exit(1)
|
|
} catch (error) {
|
|
if (process.env.DEBUG === 'true') console.log(cmd, (error as ExecError).stdout)
|
|
expect((error as ExecError).status).toBe(1)
|
|
expect((error as ExecError).stdout).toContain(
|
|
'row has the wrong line ending character, should be CRLF'
|
|
)
|
|
}
|
|
})
|
|
|
|
it('shows an error if there are duplicates in the file', () => {
|
|
let ENV_VAR = 'DATA_DIR=tests/__data__/input/db/validate/duplicate'
|
|
if (os.platform() === 'win32') {
|
|
ENV_VAR = 'SET "DATA_DIR=tests/__data__/input/db/validate/duplicate" &&'
|
|
}
|
|
const cmd = `${ENV_VAR} npm run db:validate`
|
|
try {
|
|
const stdout = execSync(cmd, { encoding: 'utf8' })
|
|
if (process.env.DEBUG === 'true') console.log(cmd, stdout)
|
|
process.exit(1)
|
|
} catch (error) {
|
|
if (process.env.DEBUG === 'true') console.log(cmd, (error as ExecError).stdout)
|
|
expect((error as ExecError).status).toBe(1)
|
|
expect((error as ExecError).stdout).toContain('category with id "aaa" already exists')
|
|
expect((error as ExecError).stdout).toContain(
|
|
'blocklist record with channel "002RadioTV.do" and ref "https://en.wikipedia.org/wiki/Lemurs_of_Madagascar_(book)" already exists'
|
|
)
|
|
expect((error as ExecError).stdout).toContain(
|
|
'feed with channel "002RadioTV.do" and id "SD" already exists'
|
|
)
|
|
expect((error as ExecError).stdout).toContain('3 error(s)')
|
|
}
|
|
})
|
|
|
|
it('shows an error if the data contains an error', () => {
|
|
let ENV_VAR = 'DATA_DIR=tests/__data__/input/db/validate/invalid_value'
|
|
if (os.platform() === 'win32') {
|
|
ENV_VAR = 'SET "DATA_DIR=tests/__data__/input/db/validate/invalid_value" &&'
|
|
}
|
|
const cmd = `${ENV_VAR} npm run db:validate`
|
|
try {
|
|
const stdout = execSync(cmd, { encoding: 'utf8' })
|
|
if (process.env.DEBUG === 'true') console.log(cmd, stdout)
|
|
process.exit(1)
|
|
} catch (error) {
|
|
if (process.env.DEBUG === 'true') console.log(cmd, (error as ExecError).stdout)
|
|
expect((error as ExecError).status).toBe(1)
|
|
expect((error as ExecError).stdout).toContain('"aaa.us" is missing from the channels.csv')
|
|
expect((error as ExecError).stdout).toContain(
|
|
'"002RadioTV.do" has an invalid replaced_by "002RadioTV.do@4K"'
|
|
)
|
|
expect((error as ExecError).stdout).toContain('"24B.do" does not have a main feed')
|
|
expect((error as ExecError).stdout).toContain(
|
|
'002RadioTV.do: "website" must be a valid uri with a scheme matching the http|https pattern'
|
|
)
|
|
expect((error as ExecError).stdout).toContain(
|
|
'"002RadioTV.do" has an more than one main feed'
|
|
)
|
|
expect((error as ExecError).stdout).toContain('"0TV.dk@SD" has the wrong channel "0TV.dk"')
|
|
expect((error as ExecError).stdout).toContain(
|
|
'"0TV.dk@SD" has the wrong broadcast_area "c/BE"'
|
|
)
|
|
expect((error as ExecError).stdout).toContain(
|
|
'"0TV.dk@SD" has the wrong timezones "Europe/Copenhagen"'
|
|
)
|
|
expect((error as ExecError).stdout).toContain(
|
|
'0TV.dk@SD: "video_format" with value "576I" fails to match the required pattern'
|
|
)
|
|
expect((error as ExecError).stdout).toContain('10 error(s)')
|
|
}
|
|
})
|
|
|
|
it('does not show an error if all data are correct', () => {
|
|
let ENV_VAR = 'DATA_DIR=tests/__data__/input/db/validate/valid_data'
|
|
if (os.platform() === 'win32') {
|
|
ENV_VAR = 'SET "DATA_DIR=tests/__data__/input/db/validate/valid_data" &&'
|
|
}
|
|
const cmd = `${ENV_VAR} npm run db:validate`
|
|
try {
|
|
const stdout = execSync(cmd, { encoding: 'utf8' })
|
|
if (process.env.DEBUG === 'true') console.log(cmd, stdout)
|
|
} catch (error) {
|
|
if (process.env.DEBUG === 'true') console.log(cmd, (error as ExecError).stdout)
|
|
process.exit(1)
|
|
}
|
|
})
|
|
})
|