Merge pull request #11925 from electron/squirrel-mac-cdn
Update to use Squirrel.Mac that supports CDN releases
This commit is contained in:
commit
67fa13d7cf
10 changed files with 138 additions and 36 deletions
|
@ -29,24 +29,6 @@ describe('autoUpdater module', function () {
|
|||
})
|
||||
})
|
||||
|
||||
describe('setFeedURL', function () {
|
||||
describe('on Mac', function () {
|
||||
before(function () {
|
||||
if (process.platform !== 'darwin') {
|
||||
this.skip()
|
||||
}
|
||||
})
|
||||
|
||||
it('emits an error when the application is unsigned', function (done) {
|
||||
ipcRenderer.once('auto-updater-error', function (event, message) {
|
||||
assert.equal(message, 'Could not get code signature for running application')
|
||||
done()
|
||||
})
|
||||
autoUpdater.setFeedURL('')
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
describe('getFeedURL', function () {
|
||||
it('returns a falsey value by default', function () {
|
||||
assert.ok(!autoUpdater.getFeedURL())
|
||||
|
@ -66,6 +48,83 @@ describe('autoUpdater module', function () {
|
|||
})
|
||||
})
|
||||
|
||||
describe('setFeedURL', function () {
|
||||
describe('on Mac or Windows', () => {
|
||||
const noThrow = (fn) => {
|
||||
try { fn() } catch (err) {}
|
||||
}
|
||||
|
||||
before(function () {
|
||||
if (process.platform !== 'win32' && process.platform !== 'darwin') {
|
||||
this.skip()
|
||||
}
|
||||
})
|
||||
|
||||
it('sets url successfully using old (url, headers) syntax', () => {
|
||||
noThrow(() => autoUpdater.setFeedURL('http://electronjs.org', { header: 'val' }))
|
||||
assert.equal(autoUpdater.getFeedURL(), 'http://electronjs.org')
|
||||
})
|
||||
|
||||
it('throws if no url is provided when using the old style', () => {
|
||||
assert.throws(
|
||||
() => autoUpdater.setFeedURL(),
|
||||
err => err.message.includes('Expected an options object with a \'url\' property to be provided') // eslint-disable-line
|
||||
)
|
||||
})
|
||||
|
||||
it('sets url successfully using new ({ url }) syntax', () => {
|
||||
noThrow(() => autoUpdater.setFeedURL({ url: 'http://mymagicurl.local' }))
|
||||
assert.equal(autoUpdater.getFeedURL(), 'http://mymagicurl.local')
|
||||
})
|
||||
|
||||
it('throws if no url is provided when using the new style', () => {
|
||||
assert.throws(
|
||||
() => autoUpdater.setFeedURL({ noUrl: 'lol' }),
|
||||
err => err.message.includes('Expected options object to contain a \'url\' string property in setFeedUrl call') // eslint-disable-line
|
||||
)
|
||||
})
|
||||
})
|
||||
|
||||
describe('on Mac', function () {
|
||||
const isServerTypeError = (err) => err.message.includes('Expected serverType to be \'default\' or \'json\'')
|
||||
|
||||
before(function () {
|
||||
if (process.platform !== 'darwin') {
|
||||
this.skip()
|
||||
}
|
||||
})
|
||||
|
||||
it('emits an error when the application is unsigned', function (done) {
|
||||
ipcRenderer.once('auto-updater-error', function (event, message) {
|
||||
assert.equal(message, 'Could not get code signature for running application')
|
||||
done()
|
||||
})
|
||||
autoUpdater.setFeedURL('')
|
||||
})
|
||||
|
||||
it('does not throw if default is the serverType', () => {
|
||||
assert.doesNotThrow(
|
||||
() => autoUpdater.setFeedURL({ url: '', serverType: 'default' }),
|
||||
isServerTypeError
|
||||
)
|
||||
})
|
||||
|
||||
it('does not throw if json is the serverType', () => {
|
||||
assert.doesNotThrow(
|
||||
() => autoUpdater.setFeedURL({ url: '', serverType: 'default' }),
|
||||
isServerTypeError
|
||||
)
|
||||
})
|
||||
|
||||
it('does throw if an unknown string is the serverType', () => {
|
||||
assert.throws(
|
||||
() => autoUpdater.setFeedURL({ url: '', serverType: 'weow' }),
|
||||
isServerTypeError
|
||||
)
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
describe('quitAndInstall', function () {
|
||||
it('emits an error on Windows when no update is available', function (done) {
|
||||
if (process.platform !== 'win32') {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue