How to test iOS push notifications using Detox
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}
We've just implemented some custom handling for push notifications in our ReactNative mobile app, and I'm trying to write integration tests for these using Detox framework.
We know the notifications are working on real devices, however the notifications never are handled in detox tests.
const favoriteNotification = {
"trigger": {
"type": "push"
},
body: 'Your awesome notification',
};
describe(`Push Notifications`, () => {
beforeAll(async () => {
await device.launchApp({
delete: true,
newInstance: true,
permissions: {notifications: 'YES'}
});
// code to login the user into the app
});
it(`app opened from the favorite notification`, async () => {
await device.launchApp({
// newInstance: true,
// permissions: {notifications: 'YES'},
userNotification: favoriteNotification
});
let element = element(by.text(favoriteNotification.body))
await waitFor(element).toExist().withTimeout(5000);
await expect(element).toExist();
});
it(`when app is in the foreground, should show an alert`, async () => {
await device.launchApp({newInstance: true, permissions: {notifications: 'YES'}});
await device.sendUserNotification(favoriteNotification);
let element = element(by.text(favoriteNotification.body))
await waitFor(element).toExist().withTimeout(5000);
await expect(element).toExist();
});
});
In both cases, absolutely nothing happens, and tests fail. Any idea how to make this work, or if it's even possible?
Detox version: 9.0.5
ReactNative version: 0.57.3
We're using react-native-notifications
ver 1.1.20 to handle notifications. Perhaps this library is incompatible with detox mocking notifications? (I couldn't find any information to confirm/reject this though).
ios react-native integration-testing detox
add a comment |
We've just implemented some custom handling for push notifications in our ReactNative mobile app, and I'm trying to write integration tests for these using Detox framework.
We know the notifications are working on real devices, however the notifications never are handled in detox tests.
const favoriteNotification = {
"trigger": {
"type": "push"
},
body: 'Your awesome notification',
};
describe(`Push Notifications`, () => {
beforeAll(async () => {
await device.launchApp({
delete: true,
newInstance: true,
permissions: {notifications: 'YES'}
});
// code to login the user into the app
});
it(`app opened from the favorite notification`, async () => {
await device.launchApp({
// newInstance: true,
// permissions: {notifications: 'YES'},
userNotification: favoriteNotification
});
let element = element(by.text(favoriteNotification.body))
await waitFor(element).toExist().withTimeout(5000);
await expect(element).toExist();
});
it(`when app is in the foreground, should show an alert`, async () => {
await device.launchApp({newInstance: true, permissions: {notifications: 'YES'}});
await device.sendUserNotification(favoriteNotification);
let element = element(by.text(favoriteNotification.body))
await waitFor(element).toExist().withTimeout(5000);
await expect(element).toExist();
});
});
In both cases, absolutely nothing happens, and tests fail. Any idea how to make this work, or if it's even possible?
Detox version: 9.0.5
ReactNative version: 0.57.3
We're using react-native-notifications
ver 1.1.20 to handle notifications. Perhaps this library is incompatible with detox mocking notifications? (I couldn't find any information to confirm/reject this though).
ios react-native integration-testing detox
You cannot receive Push Notification alerts on the iOS Simulator, therefore this isn't feasible.
– Dan
Nov 16 '18 at 15:07
Detox allows for mocking push notifications: github.com/wix/detox/wiki/Mocking-User-Notifications-and-URLs and this is what I'm trying to achieve here. It's done on the iOS simulator, as they don't support running the tests on the real device in case of iOS as far as I know.
– Magdalena
Nov 19 '18 at 12:40
add a comment |
We've just implemented some custom handling for push notifications in our ReactNative mobile app, and I'm trying to write integration tests for these using Detox framework.
We know the notifications are working on real devices, however the notifications never are handled in detox tests.
const favoriteNotification = {
"trigger": {
"type": "push"
},
body: 'Your awesome notification',
};
describe(`Push Notifications`, () => {
beforeAll(async () => {
await device.launchApp({
delete: true,
newInstance: true,
permissions: {notifications: 'YES'}
});
// code to login the user into the app
});
it(`app opened from the favorite notification`, async () => {
await device.launchApp({
// newInstance: true,
// permissions: {notifications: 'YES'},
userNotification: favoriteNotification
});
let element = element(by.text(favoriteNotification.body))
await waitFor(element).toExist().withTimeout(5000);
await expect(element).toExist();
});
it(`when app is in the foreground, should show an alert`, async () => {
await device.launchApp({newInstance: true, permissions: {notifications: 'YES'}});
await device.sendUserNotification(favoriteNotification);
let element = element(by.text(favoriteNotification.body))
await waitFor(element).toExist().withTimeout(5000);
await expect(element).toExist();
});
});
In both cases, absolutely nothing happens, and tests fail. Any idea how to make this work, or if it's even possible?
Detox version: 9.0.5
ReactNative version: 0.57.3
We're using react-native-notifications
ver 1.1.20 to handle notifications. Perhaps this library is incompatible with detox mocking notifications? (I couldn't find any information to confirm/reject this though).
ios react-native integration-testing detox
We've just implemented some custom handling for push notifications in our ReactNative mobile app, and I'm trying to write integration tests for these using Detox framework.
We know the notifications are working on real devices, however the notifications never are handled in detox tests.
const favoriteNotification = {
"trigger": {
"type": "push"
},
body: 'Your awesome notification',
};
describe(`Push Notifications`, () => {
beforeAll(async () => {
await device.launchApp({
delete: true,
newInstance: true,
permissions: {notifications: 'YES'}
});
// code to login the user into the app
});
it(`app opened from the favorite notification`, async () => {
await device.launchApp({
// newInstance: true,
// permissions: {notifications: 'YES'},
userNotification: favoriteNotification
});
let element = element(by.text(favoriteNotification.body))
await waitFor(element).toExist().withTimeout(5000);
await expect(element).toExist();
});
it(`when app is in the foreground, should show an alert`, async () => {
await device.launchApp({newInstance: true, permissions: {notifications: 'YES'}});
await device.sendUserNotification(favoriteNotification);
let element = element(by.text(favoriteNotification.body))
await waitFor(element).toExist().withTimeout(5000);
await expect(element).toExist();
});
});
In both cases, absolutely nothing happens, and tests fail. Any idea how to make this work, or if it's even possible?
Detox version: 9.0.5
ReactNative version: 0.57.3
We're using react-native-notifications
ver 1.1.20 to handle notifications. Perhaps this library is incompatible with detox mocking notifications? (I couldn't find any information to confirm/reject this though).
ios react-native integration-testing detox
ios react-native integration-testing detox
asked Nov 16 '18 at 14:34
MagdalenaMagdalena
235
235
You cannot receive Push Notification alerts on the iOS Simulator, therefore this isn't feasible.
– Dan
Nov 16 '18 at 15:07
Detox allows for mocking push notifications: github.com/wix/detox/wiki/Mocking-User-Notifications-and-URLs and this is what I'm trying to achieve here. It's done on the iOS simulator, as they don't support running the tests on the real device in case of iOS as far as I know.
– Magdalena
Nov 19 '18 at 12:40
add a comment |
You cannot receive Push Notification alerts on the iOS Simulator, therefore this isn't feasible.
– Dan
Nov 16 '18 at 15:07
Detox allows for mocking push notifications: github.com/wix/detox/wiki/Mocking-User-Notifications-and-URLs and this is what I'm trying to achieve here. It's done on the iOS simulator, as they don't support running the tests on the real device in case of iOS as far as I know.
– Magdalena
Nov 19 '18 at 12:40
You cannot receive Push Notification alerts on the iOS Simulator, therefore this isn't feasible.
– Dan
Nov 16 '18 at 15:07
You cannot receive Push Notification alerts on the iOS Simulator, therefore this isn't feasible.
– Dan
Nov 16 '18 at 15:07
Detox allows for mocking push notifications: github.com/wix/detox/wiki/Mocking-User-Notifications-and-URLs and this is what I'm trying to achieve here. It's done on the iOS simulator, as they don't support running the tests on the real device in case of iOS as far as I know.
– Magdalena
Nov 19 '18 at 12:40
Detox allows for mocking push notifications: github.com/wix/detox/wiki/Mocking-User-Notifications-and-URLs and this is what I'm trying to achieve here. It's done on the iOS simulator, as they don't support running the tests on the real device in case of iOS as far as I know.
– Magdalena
Nov 19 '18 at 12:40
add a comment |
0
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53339883%2fhow-to-test-ios-push-notifications-using-detox%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53339883%2fhow-to-test-ios-push-notifications-using-detox%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
You cannot receive Push Notification alerts on the iOS Simulator, therefore this isn't feasible.
– Dan
Nov 16 '18 at 15:07
Detox allows for mocking push notifications: github.com/wix/detox/wiki/Mocking-User-Notifications-and-URLs and this is what I'm trying to achieve here. It's done on the iOS simulator, as they don't support running the tests on the real device in case of iOS as far as I know.
– Magdalena
Nov 19 '18 at 12:40