diff --git a/sites/epgshare01.online/epgshare01.online.test.js b/sites/epgshare01.online/epgshare01.online.test.js new file mode 100644 index 00000000..88015351 --- /dev/null +++ b/sites/epgshare01.online/epgshare01.online.test.js @@ -0,0 +1,43 @@ +const { parser, url } = require('./epgshare01.online.config.js') +const fs = require('fs') +const path = require('path') +const dayjs = require('dayjs') +const utc = require('dayjs/plugin/utc') +const customParseFormat = require('dayjs/plugin/customParseFormat') +dayjs.extend(customParseFormat) +dayjs.extend(utc) + +const date = dayjs.utc('2025-02-09', 'YYYY-MM-DD').startOf('d') +const channel = { site_id: 'ALJAZEERA1#AlJazeera.English.net' } + +it('can generate valid url', () => { + expect(url({ channel })).toBe('https://epgshare01.online/epgshare01/epg_ripper_ALJAZEERA1.xml.gz') +}) + +it('can parse response', () => { + const buffer = fs.readFileSync(path.resolve(__dirname, '__data__/content.xml.gz')) + + const results = parser({ buffer, channel, date, cached: false }) + + expect(results.length).toBe(40) + expect(results[0]).toMatchObject({ + title: 'The Palestine Laboratory', + description: + "Exposing how Israel's sales of military technology is aiding state control around the world.", + start: '2025-02-09T00:00:00.000Z', + stop: '2025-02-09T01:00:00.000Z' + }) + expect(results[39]).toMatchObject({ + title: 'Inside Story', + description: + 'Beyond the headlines to the heart of the news of the day. Al Jazeera gets the Inside Story from some of the best minds from around the globe.', + start: '2025-02-09T23:30:00.000Z', + stop: '2025-02-10T00:00:00.000Z' + }) +}) + +it('can handle empty guide', () => { + const results = parser({ content: '', channel, date, cached: false }) + + expect(results).toMatchObject([]) +})