forked from boyska/radiomanifest.js
basic karma/mocha test suite setup
This commit is contained in:
parent
af9f6c2598
commit
221430c017
5 changed files with 229 additions and 90 deletions
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
node_modules
|
34
karma.config.js
Normal file
34
karma.config.js
Normal file
|
@ -0,0 +1,34 @@
|
|||
module.exports = function (config) {
|
||||
config.set({
|
||||
frameworks: ['mocha'],
|
||||
// plugins: ['karma-webpack', 'karma-mocha', 'karma-chai-as-promised'],
|
||||
webpack: {
|
||||
// karma watches the test entry points
|
||||
// Do NOT specify the entry option
|
||||
// webpack watches dependencies
|
||||
|
||||
// webpack configuration
|
||||
},
|
||||
preprocessors: {
|
||||
'test/**/*.js': ['webpack'],
|
||||
'radiomanifest.js': ['webpack']
|
||||
},
|
||||
files: [
|
||||
'radiomanifest.js',
|
||||
'test/**/*.js'
|
||||
],
|
||||
reporters: ['progress'],
|
||||
port: 9876, // karma web server port
|
||||
colors: true,
|
||||
logLevel: config.LOG_INFO,
|
||||
browsers: ['ChromeHeadless', 'FirefoxHeadless'],
|
||||
autoWatch: false,
|
||||
concurrency: Infinity,
|
||||
customLaunchers: {
|
||||
FirefoxHeadless: {
|
||||
base: 'Firefox',
|
||||
flags: ['-headless'],
|
||||
},
|
||||
},
|
||||
})
|
||||
}
|
34
package.json
Normal file
34
package.json
Normal file
|
@ -0,0 +1,34 @@
|
|||
{
|
||||
"name": "radiomanifest",
|
||||
"version": "0.1.0",
|
||||
"description": "",
|
||||
"main": "radiomanifest.js",
|
||||
"directories": {
|
||||
"test": "tests"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "gogs@git.lattuga.net:lesion/radiomanifest.js.git"
|
||||
},
|
||||
"scripts": {
|
||||
"test": "npm run test:node && npm run test:browser",
|
||||
"test:node": "mocha",
|
||||
"test:browser": "karma start --single-run --browsers ChromeHeadless,FirefoxHeadless karma.config.js"
|
||||
},
|
||||
"author": "",
|
||||
"license": "ISC",
|
||||
"devDependencies": {
|
||||
"chai": "^4.3.4",
|
||||
"chai-as-promised": "^7.1.1",
|
||||
"karma": "^6.3.9",
|
||||
"karma-chrome-launcher": "^3.1.0",
|
||||
"karma-firefox-launcher": "^2.1.2",
|
||||
"karma-mocha": "^2.0.1",
|
||||
"karma-webpack": "^5.0.0",
|
||||
"mocha": "^9.1.3",
|
||||
"webpack": "^5.64.1"
|
||||
},
|
||||
"dependencies": {
|
||||
"isomorphic-unfetch": "^3.1.0"
|
||||
}
|
||||
}
|
|
@ -1,3 +1,42 @@
|
|||
const fetch = require('isomorphic-unfetch')
|
||||
module.exports = {
|
||||
|
||||
/**
|
||||
*
|
||||
* @param {String} baseURL to search for a radiomanifest
|
||||
*/
|
||||
get (baseURL, options = { shows: false, streaming: false, calendar: false }) {
|
||||
return new RadioManifest(baseURL, options )
|
||||
}
|
||||
}
|
||||
|
||||
class RadioManifest {
|
||||
constructor (baseURL, options) {
|
||||
this.baseURL = baseURL
|
||||
this.options = options
|
||||
|
||||
const radiomanifest = fetch(`${baseURL}/radiomanifest.xml`)
|
||||
return radiomanifest
|
||||
}
|
||||
|
||||
getShowByName (showName) {
|
||||
|
||||
}
|
||||
|
||||
getStreaming () {
|
||||
|
||||
}
|
||||
|
||||
getSchedule () {
|
||||
|
||||
}
|
||||
|
||||
getShowAtTime () {
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
function getStreaminfoUrl(siteurl) {
|
||||
return siteurl + '/streaminfo.json'; // XXX: improve this logic
|
||||
}
|
||||
|
|
31
test/radiomanifest.test.js
Normal file
31
test/radiomanifest.test.js
Normal file
|
@ -0,0 +1,31 @@
|
|||
const radiomanifest = require('../radiomanifest.js')
|
||||
const chai = require('chai')
|
||||
chai.use(require('chai-as-promised'))
|
||||
|
||||
const expect = chai.expect
|
||||
|
||||
describe('radiomanifest.js', () => {
|
||||
|
||||
describe('Get a radiomanifest', () => {
|
||||
|
||||
it('should return a Promise', () => {
|
||||
const p = radiomanifest.get('http://omstring')
|
||||
expect(p instanceof Promise).to.be.eql(true)
|
||||
})
|
||||
|
||||
it('should reject on invalid URL', () => {
|
||||
const p = radiomanifest.get('http://invalidurl')
|
||||
expect(p).to.eventually.be.rejected
|
||||
})
|
||||
|
||||
})
|
||||
|
||||
describe('streaming', () => {
|
||||
it('shoud return a valid streaming URL', () => {
|
||||
|
||||
})
|
||||
})
|
||||
|
||||
|
||||
|
||||
})
|
Loading…
Reference in a new issue