diff --git a/sites/mncvision.id/mncvision.id.test.js b/sites/mncvision.id/mncvision.id.test.js
index faa3ee3e..91c2ddd3 100644
--- a/sites/mncvision.id/mncvision.id.test.js
+++ b/sites/mncvision.id/mncvision.id.test.js
@@ -1,8 +1,10 @@
+// npx epg-grabber --config=sites/mncvision.id/mncvision.id.config.js --channels=sites/mncvision.id/mncvision.id_id-id.channels.xml --output=guide.xml --timeout=30000 --days=2
+// npx epg-grabber --config=sites/mncvision.id/mncvision.id.config.js --channels=sites/mncvision.id/mncvision.id_id-en.channels.xml --output=guide.xml --timeout=30000 --days=2
// node ./scripts/channels.js --config=./sites/mncvision.id/mncvision.id.config.js --output=./sites/mncvision.id/mncvision.id_id.channels.xml
-// npx epg-grabber --config=sites/mncvision.id/mncvision.id.config.js --channels=sites/mncvision.id/mncvision.id_id-id.channels.xml --output=guide.xml --days=2
-// npx epg-grabber --config=sites/mncvision.id/mncvision.id.config.js --channels=sites/mncvision.id/mncvision.id_id-en.channels.xml --output=guide.xml --days=2
const { parser, url, request } = require('./mncvision.id.config.js')
+const fs = require('fs')
+const path = require('path')
const axios = require('axios')
const dayjs = require('dayjs')
const utc = require('dayjs/plugin/utc')
@@ -12,181 +14,138 @@ dayjs.extend(utc)
jest.mock('axios')
-const date = dayjs.utc('2021-11-12', 'YYYY-MM-DD').startOf('d')
-const channelID = {
- site_id: '203',
- xmltv_id: 'AnimalPlanetSoutheastAsia.us',
+const date = dayjs.utc('2022-10-05', 'YYYY-MM-DD').startOf('d')
+const channel = {
+ site_id: '38',
+ xmltv_id: 'MiaoMi.hk',
lang: 'id'
}
-const channelEN = {
- site_id: '203',
- xmltv_id: 'AnimalPlanetSoutheastAsia.us',
- lang: 'en'
+const headers = {
+ 'set-cookie': [
+ 's1nd0vL=05e9pr6gi112tdmutsn7big93o75r0b0; expires=Wed, 05-Oct-2022 14:18:22 GMT; Max-Age=7200; path=/; HttpOnly'
+ ]
}
-const setCookie = [
- 's1nd0vL=0qpsmm7dpjmi7nt8d2h5epf16rmgg8a8; expires=Sat, 05-Mar-2022 15:44:22 GMT; Max-Age=7200; path=/; HttpOnly'
-]
-
-const content0 = `
Jadwal Tayang Channel: 41 Tanggal: 2022-03-05
`
-const content50 = ` Jadwal Tayang Channel: 41 Tanggal: 2022-03-05
`
it('can generate valid url', () => {
expect(url).toBe('https://mncvision.id/schedule/table')
})
+it('can generate valid request method', () => {
+ expect(request.method).toBe('POST')
+})
+
it('can generate valid request headers', () => {
expect(request.headers).toMatchObject({
- 'Content-Type': 'multipart/form-data; boundary=X-EPG-BOUNDARY'
+ 'Content-Type': 'application/x-www-form-urlencoded'
})
})
it('can generate valid request data', () => {
- const result = request.data({ channel: channelID, date })
- expect(result._boundary).toBe('X-EPG-BOUNDARY')
+ const data = request.data({ channel, date })
+ expect(data.get('search_model')).toBe('channel')
+ expect(data.get('af0rmelement')).toBe('aformelement')
+ expect(data.get('fdate')).toBe('2022-10-05')
+ expect(data.get('fchannel')).toBe('38')
+ expect(data.get('submit')).toBe('Search')
})
-it('can parse response in Indonesian', done => {
- const setLangCookie = [
- 's1nd0vL=oj87dbpo7cqbg8fit3295075kodja8hl; expires=Fri, 11-Mar-2022 14:40:17 GMT; Max-Age=7200; path=/; HttpOnly'
- ]
-
- axios.get.mockImplementation((url, options = {}) => {
+it('can parse response', async () => {
+ const content = fs.readFileSync(path.resolve(__dirname, '__data__/content.html'))
+ const indonesiaHeaders = {
+ 'set-cookie': [
+ 's1nd0vL=e3vjb0oaf9vijiqsg7cml4i7fdkq16db; expires=Wed, 05-Oct-2022 14:54:16 GMT; Max-Age=7200; path=/; HttpOnly'
+ ]
+ }
+ const englishHeaders = {
+ 'set-cookie': [
+ 's1nd0vL=hfd6hpnpr6gvgart0d8rf7ef6t4gi7nr; expires=Wed, 05-Oct-2022 15:08:55 GMT; Max-Age=7200; path=/; HttpOnly'
+ ]
+ }
+ axios.get.mockImplementation((url, opts) => {
if (
url === 'https://www.mncvision.id/schedule/table/startno/50' &&
- options.headers &&
- options.headers['Cookie'] === setCookie.join(';')
+ opts.headers['Cookie'] === headers['set-cookie'][0]
) {
return Promise.resolve({
- data: content50
+ data: fs.readFileSync(path.resolve(__dirname, '__data__/content_p2.html'))
})
} else if (url === 'https://www.mncvision.id/language_switcher/setlang/indonesia/') {
return Promise.resolve({
- headers: {
- 'set-cookie': setLangCookie
- }
- })
- } else if (
- url === 'https://www.mncvision.id/schedule/detail/2022030500000041/Hey-Duggee-S3-Ep-22/1' &&
- options.headers &&
- options.headers['X-Requested-With'] === 'XMLHttpRequest' &&
- options.headers['Cookie'] === setLangCookie.join(';')
- ) {
- return Promise.resolve({
- data: `
- Nikmati suasana kehidupan koloni anjing laut di kawasan pantai barat Afrika Selatan.
`
- })
- }
-
- return Promise.resolve({ data: '' })
- })
-
- parser({ date, content: content0, headers: { 'set-cookie': setCookie }, channel: channelID })
- .then(result => {
- result = result.map(p => {
- p.start = p.start.toJSON()
- p.stop = p.stop.toJSON()
- return p
- })
-
- expect(result).toMatchObject([
- {
- start: '2021-11-11T17:00:00.000Z',
- stop: '2021-11-11T17:07:00.000Z',
- title: 'Hey Duggee S3, Ep 22',
- description:
- 'Nikmati suasana kehidupan koloni anjing laut di kawasan pantai barat Afrika Selatan.'
- },
- {
- start: '2021-11-12T01:25:00.000Z',
- stop: '2021-11-12T01:32:00.000Z',
- title: 'Hey Duggee S1, Ep 46',
- description: null
- }
- ])
- done()
- })
- .catch(error => {
- done(error)
- })
-})
-
-it('can parse response in English', done => {
- const setLangCookie = [
- 's1nd0vL=4li9qu3olhjl9djrl971opl2tgb27p1v; expires=Fri, 11-Mar-2022 14:26:55 GMT; Max-Age=7200; path=/; HttpOnly'
- ]
-
- axios.get.mockImplementation((url, options = {}) => {
- if (
- url === 'https://www.mncvision.id/schedule/table/startno/50' &&
- options.headers &&
- options.headers['Cookie'] === setCookie.join(';')
- ) {
- return Promise.resolve({
- data: content50
+ headers: indonesiaHeaders
})
} else if (url === 'https://www.mncvision.id/language_switcher/setlang/english/') {
return Promise.resolve({
- headers: {
- 'set-cookie': setLangCookie
- }
+ headers: englishHeaders
})
} else if (
- url === 'https://www.mncvision.id/schedule/detail/2022030500000041/Hey-Duggee-S3-Ep-22/1' &&
- options.headers &&
- options.headers['X-Requested-With'] === 'XMLHttpRequest' &&
- options.headers['Cookie'] === setLangCookie.join(';')
+ url ===
+ 'https://mncvision.id/schedule/detail/2022100500000038/Adventures-With-Miao-Mi-Ep-1/1' &&
+ opts.headers['Cookie'] === indonesiaHeaders['set-cookie'][0]
) {
return Promise.resolve({
- data: `
- While Castiel investigates the disappearance of a local teen, Sam and Dean are visited by an old friend.
`
+ data: fs.readFileSync(path.resolve(__dirname, '__data__/program_id.html'))
+ })
+ } else if (
+ url ===
+ 'https://mncvision.id/schedule/detail/2022100500000038/Adventures-With-Miao-Mi-Ep-1/1' &&
+ opts.headers['Cookie'] === englishHeaders['set-cookie'][0]
+ ) {
+ return Promise.resolve({
+ data: fs.readFileSync(path.resolve(__dirname, '__data__/program_en.html'))
})
}
return Promise.resolve({ data: '' })
})
- parser({ date, content: content0, headers: { 'set-cookie': setCookie }, channel: channelEN })
- .then(result => {
- result = result.map(p => {
- p.start = p.start.toJSON()
- p.stop = p.stop.toJSON()
- return p
- })
-
- expect(result).toMatchObject([
- {
- start: '2021-11-11T17:00:00.000Z',
- stop: '2021-11-11T17:07:00.000Z',
- title: 'Hey Duggee S3, Ep 22',
- description:
- 'While Castiel investigates the disappearance of a local teen, Sam and Dean are visited by an old friend.'
- },
- {
- start: '2021-11-12T01:25:00.000Z',
- stop: '2021-11-12T01:32:00.000Z',
- title: 'Hey Duggee S1, Ep 46',
- description: null
- }
- ])
- done()
- })
- .catch(error => {
- done(error)
- })
-})
-
-it('can handle empty guide', done => {
- parser({
- date,
- channel: channelID,
- content: ``,
- headers: { 'set-cookie': setCookie }
+ let indonesiaResults = await parser({ date, content, channel, headers })
+ indonesiaResults = indonesiaResults.map(p => {
+ p.start = p.start.toJSON()
+ p.stop = p.stop.toJSON()
+ return p
+ })
+
+ expect(indonesiaResults[0]).toMatchObject({
+ start: '2022-10-04T17:00:00.000Z',
+ stop: '2022-10-04T17:06:00.000Z',
+ title: 'Adventures With Miao Mi, Ep 1',
+ episode: 1,
+ description:
+ 'Ketika anak-anak mulai menghilang, sekelompok anak kecil harus menghadapi ketakutan terbesar mereka ketika mereka melawan sesosok badut pembunuh yang jahat.'
+ })
+
+ expect(indonesiaResults[4]).toMatchObject({
+ start: '2022-10-04T17:33:00.000Z',
+ stop: '2022-10-04T17:46:00.000Z',
+ title: 'Leo Wildlife Ranger S2, Ep 27',
+ season: 2,
+ episode: 27
+ })
+
+ let englishResults = await parser({ date, content, channel: { ...channel, lang: 'en' }, headers })
+ englishResults = englishResults.map(p => {
+ p.start = p.start.toJSON()
+ p.stop = p.stop.toJSON()
+ return p
+ })
+
+ expect(englishResults[0]).toMatchObject({
+ start: '2022-10-04T17:00:00.000Z',
+ stop: '2022-10-04T17:06:00.000Z',
+ title: 'Adventures With Miao Mi, Ep 1',
+ episode: 1,
+ description:
+ 'When children begin to disappear, a group of young kids have to face their biggest fears when they square off against a murderous, evil clown.'
})
- .then(result => {
- expect(result).toMatchObject([])
- done()
- })
- .catch(error => {
- done(error)
- })
+})
+
+it('can handle empty guide', async () => {
+ const content = fs.readFileSync(path.resolve(__dirname, '__data__/no_content.html'))
+ let results = await parser({
+ date,
+ channel,
+ content,
+ headers
+ })
+ expect(results).toMatchObject([])
})