2017-08-04 20:36:27 +02:00
|
|
|
const assert = require('assert')
|
Close window after opening fullscreen (#6966)
* Add background environment type
The `getEnvironmentType` method now checks for the background
environment as well, instead of returning 'notification' for that case.
Instead of adding another regex for the background path, the regexes
for each environment have been replaced with the URL constructor[0].
This is the standard method of parsing URLs, and is available in all
supported browsers.
[0]: https://developer.mozilla.org/en-US/docs/Web/API/URL
* Add note regarding a missing manifest permission
The `url` parameter to `tabs.query(...)` requires the `tabs` permission,
and will be ignored otherwise. We are missing this permission, so that
call does not work.
* Close window after opening full screen
The browser behaviour when opening a new tab differs between Chrome and
Firefox. In the case of a popup, Chrome will close the popup whereas
Firefox will leave it open. In the case of the notification window,
Chrome will move the new tab to the foreground, whereas Firefox will
leave the notification window in the foreground when opening a new tab.
We always want to close the current UI (popup or notification) when
switching to a full-screen view. The only exception to this is when the
switch is triggered from the background, which has no UI.
Closes #6513, #6685
2019-08-08 16:50:32 +02:00
|
|
|
const { getEnvironmentType, sufficientBalance } = require('../../../app/scripts/lib/util')
|
|
|
|
const {
|
|
|
|
ENVIRONMENT_TYPE_POPUP,
|
|
|
|
ENVIRONMENT_TYPE_NOTIFICATION,
|
|
|
|
ENVIRONMENT_TYPE_FULLSCREEN,
|
|
|
|
ENVIRONMENT_TYPE_BACKGROUND,
|
|
|
|
} = require('../../../app/scripts/lib/enums')
|
2017-08-04 20:36:27 +02:00
|
|
|
|
Close window after opening fullscreen (#6966)
* Add background environment type
The `getEnvironmentType` method now checks for the background
environment as well, instead of returning 'notification' for that case.
Instead of adding another regex for the background path, the regexes
for each environment have been replaced with the URL constructor[0].
This is the standard method of parsing URLs, and is available in all
supported browsers.
[0]: https://developer.mozilla.org/en-US/docs/Web/API/URL
* Add note regarding a missing manifest permission
The `url` parameter to `tabs.query(...)` requires the `tabs` permission,
and will be ignored otherwise. We are missing this permission, so that
call does not work.
* Close window after opening full screen
The browser behaviour when opening a new tab differs between Chrome and
Firefox. In the case of a popup, Chrome will close the popup whereas
Firefox will leave it open. In the case of the notification window,
Chrome will move the new tab to the foreground, whereas Firefox will
leave the notification window in the foreground when opening a new tab.
We always want to close the current UI (popup or notification) when
switching to a full-screen view. The only exception to this is when the
switch is triggered from the background, which has no UI.
Closes #6513, #6685
2019-08-08 16:50:32 +02:00
|
|
|
describe('getEnvironmentType', function () {
|
|
|
|
it('should return popup type', function () {
|
|
|
|
const environmentType = getEnvironmentType('http://extension-id/popup.html')
|
|
|
|
assert.equal(environmentType, ENVIRONMENT_TYPE_POPUP)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return notification type', function () {
|
|
|
|
const environmentType = getEnvironmentType('http://extension-id/notification.html')
|
|
|
|
assert.equal(environmentType, ENVIRONMENT_TYPE_NOTIFICATION)
|
|
|
|
})
|
|
|
|
|
2019-10-18 18:05:32 +02:00
|
|
|
it('should return fullscreen type for home.html', function () {
|
Close window after opening fullscreen (#6966)
* Add background environment type
The `getEnvironmentType` method now checks for the background
environment as well, instead of returning 'notification' for that case.
Instead of adding another regex for the background path, the regexes
for each environment have been replaced with the URL constructor[0].
This is the standard method of parsing URLs, and is available in all
supported browsers.
[0]: https://developer.mozilla.org/en-US/docs/Web/API/URL
* Add note regarding a missing manifest permission
The `url` parameter to `tabs.query(...)` requires the `tabs` permission,
and will be ignored otherwise. We are missing this permission, so that
call does not work.
* Close window after opening full screen
The browser behaviour when opening a new tab differs between Chrome and
Firefox. In the case of a popup, Chrome will close the popup whereas
Firefox will leave it open. In the case of the notification window,
Chrome will move the new tab to the foreground, whereas Firefox will
leave the notification window in the foreground when opening a new tab.
We always want to close the current UI (popup or notification) when
switching to a full-screen view. The only exception to this is when the
switch is triggered from the background, which has no UI.
Closes #6513, #6685
2019-08-08 16:50:32 +02:00
|
|
|
const environmentType = getEnvironmentType('http://extension-id/home.html')
|
|
|
|
assert.equal(environmentType, ENVIRONMENT_TYPE_FULLSCREEN)
|
|
|
|
})
|
|
|
|
|
2019-10-18 18:05:32 +02:00
|
|
|
it('should return fullscreen type for phishing.html', function () {
|
|
|
|
const environmentType = getEnvironmentType('http://extension-id/phishing.html')
|
|
|
|
assert.equal(environmentType, ENVIRONMENT_TYPE_FULLSCREEN)
|
|
|
|
})
|
|
|
|
|
Close window after opening fullscreen (#6966)
* Add background environment type
The `getEnvironmentType` method now checks for the background
environment as well, instead of returning 'notification' for that case.
Instead of adding another regex for the background path, the regexes
for each environment have been replaced with the URL constructor[0].
This is the standard method of parsing URLs, and is available in all
supported browsers.
[0]: https://developer.mozilla.org/en-US/docs/Web/API/URL
* Add note regarding a missing manifest permission
The `url` parameter to `tabs.query(...)` requires the `tabs` permission,
and will be ignored otherwise. We are missing this permission, so that
call does not work.
* Close window after opening full screen
The browser behaviour when opening a new tab differs between Chrome and
Firefox. In the case of a popup, Chrome will close the popup whereas
Firefox will leave it open. In the case of the notification window,
Chrome will move the new tab to the foreground, whereas Firefox will
leave the notification window in the foreground when opening a new tab.
We always want to close the current UI (popup or notification) when
switching to a full-screen view. The only exception to this is when the
switch is triggered from the background, which has no UI.
Closes #6513, #6685
2019-08-08 16:50:32 +02:00
|
|
|
it('should return background type', function () {
|
|
|
|
const environmentType = getEnvironmentType('http://extension-id/_generated_background_page.html')
|
|
|
|
assert.equal(environmentType, ENVIRONMENT_TYPE_BACKGROUND)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return the correct type for a URL with a hash fragment', function () {
|
|
|
|
const environmentType = getEnvironmentType('http://extension-id/popup.html#hash')
|
|
|
|
assert.equal(environmentType, ENVIRONMENT_TYPE_POPUP)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return the correct type for a URL with query parameters', function () {
|
|
|
|
const environmentType = getEnvironmentType('http://extension-id/popup.html?param=foo')
|
|
|
|
assert.equal(environmentType, ENVIRONMENT_TYPE_POPUP)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return the correct type for a URL with query parameters and a hash fragment', function () {
|
|
|
|
const environmentType = getEnvironmentType('http://extension-id/popup.html?param=foo#hash')
|
|
|
|
assert.equal(environmentType, ENVIRONMENT_TYPE_POPUP)
|
|
|
|
})
|
|
|
|
})
|
2017-08-04 20:36:27 +02:00
|
|
|
|
2017-08-04 20:40:22 +02:00
|
|
|
describe('SufficientBalance', function () {
|
2017-08-04 20:36:27 +02:00
|
|
|
it('returns true if max tx cost is equal to balance.', function () {
|
|
|
|
const tx = {
|
|
|
|
'value': '0x1',
|
|
|
|
'gas': '0x2',
|
|
|
|
'gasPrice': '0x3',
|
|
|
|
}
|
|
|
|
const balance = '0x8'
|
|
|
|
|
|
|
|
const result = sufficientBalance(tx, balance)
|
|
|
|
assert.ok(result, 'sufficient balance found.')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('returns true if max tx cost is less than balance.', function () {
|
|
|
|
const tx = {
|
|
|
|
'value': '0x1',
|
|
|
|
'gas': '0x2',
|
|
|
|
'gasPrice': '0x3',
|
|
|
|
}
|
|
|
|
const balance = '0x9'
|
|
|
|
|
|
|
|
const result = sufficientBalance(tx, balance)
|
|
|
|
assert.ok(result, 'sufficient balance found.')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('returns false if max tx cost is more than balance.', function () {
|
|
|
|
const tx = {
|
|
|
|
'value': '0x1',
|
|
|
|
'gas': '0x2',
|
|
|
|
'gasPrice': '0x3',
|
|
|
|
}
|
|
|
|
const balance = '0x6'
|
|
|
|
|
|
|
|
const result = sufficientBalance(tx, balance)
|
|
|
|
assert.ok(!result, 'insufficient balance found.')
|
|
|
|
})
|
2018-07-03 00:49:33 +02:00
|
|
|
})
|