diff --git a/sites/kvf.fo/__data__/example.html b/sites/kvf.fo/__data__/example.html new file mode 100644 index 00000000..5d739ee3 --- /dev/null +++ b/sites/kvf.fo/__data__/example.html @@ -0,0 +1,1008 @@ + + + + + + + + + + + + + + | Kringvarp Føroya + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + + +
+ + + +
+ + + +
+ + +
+ +
+
+ + +

+ +
+
+ + +
+
+
+
+
+
+
+ + + +
+ +
+ + +
+
+
+
+
+
+
+
+
+
+ + + +
+
+
+ +
+
+
+

fríggjadagur

+

1. juli 2022

+
+ +
+
+ + + +
+
+ +
+
10:00 - 10:29
+
+
+ +
+
10:30 - 10:50
+
Heimafimleikur við Sofíu 8:20
+
+ +
+
18:05 - 18:30
+
Letibygd 13
+
+ +
+
18:30 - 18:51
+
MORSA 3:12
+
+ +
+
19:00 - 19:25
+
Dagur og vika
+
+ +
+
19:35 - 20:15
+
Gekkur
+
+ +
+
20:15 - 21:51
+
The Duff
+
+ +
+
21:50 - 22:43
+
Melvin Kakooza Show 1
+
+ +
+
22:45 - 23:10
+
Dagur og vika
+
+ +
+
23:10 - 00:46
+
Non-Stop
+
+ + + + + + +
+ + +
+
+
+
+
+
+ + + + + + +
+
+ + + +
+
+
+
+
Nýggjastu sendingar í SV
+ +
+ + + +
+
+ + +
Mánadag 27. juni
+
3-2
+
141573
+
+ + +
Sunnudag 26. juni
+
Andakt við Róland í Skorini
+
141518
+
+ + +
Leygardag 25. juni
+
Video: 5mf kvinnur, jóansøka 2022
+
141491
+
+ + +
Leygardag 25. juni
+
Video: 10mf, jóansøka 2022
+
141489
+
+ + +
Leygardag 25. juni
+
Video: 5mf dreingir, 17-18 ár, jóansøka 2022
+
141488
+
+ + + + + + +
+ + +
+
+
+
+
+
+
+ +
+
+
+ + +
+ +
+ + + + + + + + + + + + + diff --git a/sites/kvf.fo/kvf.fo.config.js b/sites/kvf.fo/kvf.fo.config.js index d09cc65c..5b869781 100644 --- a/sites/kvf.fo/kvf.fo.config.js +++ b/sites/kvf.fo/kvf.fo.config.js @@ -11,7 +11,7 @@ dayjs.extend(customParseFormat) module.exports = { site: 'kvf.fo', url({ date }) { - return `https://kvf.fo/nskra/uv?date=${date.format('YYYY-MM-DD')}` + return `https://kvf.fo/nskra/sv?date=${date.format('YYYY-MM-DD')}` }, parser({ content, date }) { let programs = [] @@ -20,6 +20,7 @@ module.exports = { const prev = programs[programs.length - 1] const $item = cheerio.load(item) let start = parseStart($item, date) + if (!start) return if (prev && start.isBefore(prev.stop)) { start = start.add(1, 'd') date = date.add(1, 'd') @@ -65,7 +66,5 @@ function parseTitle($item) { function parseItems(content) { const $ = cheerio.load(content) - return $( - '#block-system-main > div > div > div.panels-flexible-row.panels-flexible-row-339-main-row.panels-flexible-row-last.clearfix > div > div.panels-flexible-region.panels-flexible-region-339-center.panels-flexible-region-first > div > div > div > div > div.view-content > div.views-row' - ).toArray() + return $('.view > .view-content > div.views-row').toArray() } diff --git a/sites/kvf.fo/kvf.fo.test.js b/sites/kvf.fo/kvf.fo.test.js index 181d6515..2493c982 100644 --- a/sites/kvf.fo/kvf.fo.test.js +++ b/sites/kvf.fo/kvf.fo.test.js @@ -1,6 +1,8 @@ -// npx epg-grabber --config=sites/kvf.fo/kvf.fo.config.js --channels=sites/kvf.fo/kvf.fo_fo.channels.xml --output=.gh-pages/guides/fo/kvf.fo.epg.xml --days=2 +// npx epg-grabber --config=sites/kvf.fo/kvf.fo.config.js --channels=sites/kvf.fo/kvf.fo_fo.channels.xml --output=guide.xml --days=2 const { parser, url } = require('./kvf.fo.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') @@ -14,34 +16,22 @@ const channel = { } it('can generate valid url', () => { - expect(url({ date })).toBe('https://kvf.fo/nskra/uv?date=2021-11-21') + expect(url({ date })).toBe('https://kvf.fo/nskra/sv?date=2021-11-21') }) it('can parse response', () => { - const content = `
00:00 - 02:00
Plátubarrin
23:00 - 00:00
Tónleikur
00:00 - 01:00
Náttarrásin
` + const content = fs.readFileSync(path.resolve(__dirname, './__data__/example.html')) const result = parser({ content, date }).map(p => { p.start = p.start.toJSON() p.stop = p.stop.toJSON() return p }) - expect(result).toMatchObject([ - { - start: '2021-11-21T00:00:00.000Z', - stop: '2021-11-21T02:00:00.000Z', - title: `Plátubarrin` - }, - { - start: '2021-11-21T23:00:00.000Z', - stop: '2021-11-22T00:00:00.000Z', - title: `Tónleikur` - }, - { - start: '2021-11-22T00:00:00.000Z', - stop: '2021-11-22T01:00:00.000Z', - title: `Náttarrásin` - } - ]) + expect(result[2]).toMatchObject({ + start: '2021-11-21T18:05:00.000Z', + stop: '2021-11-21T18:30:00.000Z', + title: `Letibygd 13` + }) }) it('can handle empty guide', () => {