-
Notifications
You must be signed in to change notification settings - Fork 205
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #430 from bugsnag/stop-sessions-mazerunner-tests
Add mazerunner scenarios for stopping/resuming a session
- Loading branch information
Showing
5 changed files
with
147 additions
and
7 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
37 changes: 37 additions & 0 deletions
37
...s/mazerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/NewSessionScenario.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
package com.bugsnag.android.mazerunner.scenarios | ||
|
||
import android.content.Context | ||
import com.bugsnag.android.Bugsnag | ||
import com.bugsnag.android.Configuration | ||
import android.os.Handler | ||
import android.os.HandlerThread | ||
|
||
/** | ||
* Sends an exception after stopping the session | ||
*/ | ||
internal class NewSessionScenario(config: Configuration, | ||
context: Context) : Scenario(config, context) { | ||
init { | ||
config.setAutoCaptureSessions(false) | ||
} | ||
|
||
override fun run() { | ||
super.run() | ||
val client = Bugsnag.getClient() | ||
val thread = HandlerThread("HandlerThread") | ||
thread.start() | ||
|
||
Handler(thread.looper).post { | ||
// send 1st exception which should include session info | ||
client.startSession() | ||
client.notifyBlocking(generateException()) | ||
|
||
// stop tracking the existing session | ||
client.stopSession() | ||
|
||
// send 2nd exception which should contain new session info | ||
client.startSession() | ||
client.notifyBlocking(generateException()) | ||
} | ||
} | ||
} |
35 changes: 35 additions & 0 deletions
35
...zerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/ResumedSessionScenario.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
package com.bugsnag.android.mazerunner.scenarios | ||
|
||
import android.content.Context | ||
import com.bugsnag.android.Bugsnag | ||
import com.bugsnag.android.Configuration | ||
import android.os.Handler | ||
import android.os.HandlerThread | ||
|
||
/** | ||
* Sends 2 exceptions, 1 before resuming a session, and 1 after resuming a session. | ||
*/ | ||
internal class ResumedSessionScenario(config: Configuration, | ||
context: Context) : Scenario(config, context) { | ||
init { | ||
config.setAutoCaptureSessions(false) | ||
} | ||
|
||
override fun run() { | ||
super.run() | ||
val client = Bugsnag.getClient() | ||
val thread = HandlerThread("HandlerThread") | ||
thread.start() | ||
|
||
Handler(thread.looper).post { | ||
// send 1st exception | ||
client.startSession() | ||
client.notifyBlocking(generateException()) | ||
|
||
// send 2nd exception after resuming a session | ||
client.stopSession() | ||
client.resumeSession() | ||
client.notifyBlocking(generateException()) | ||
} | ||
} | ||
} |
34 changes: 34 additions & 0 deletions
34
...zerunner/src/main/java/com/bugsnag/android/mazerunner/scenarios/StoppedSessionScenario.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
package com.bugsnag.android.mazerunner.scenarios | ||
|
||
import android.content.Context | ||
import com.bugsnag.android.Bugsnag | ||
import com.bugsnag.android.Configuration | ||
import android.os.Handler | ||
import android.os.HandlerThread | ||
|
||
/** | ||
* Sends an exception after stopping the session | ||
*/ | ||
internal class StoppedSessionScenario(config: Configuration, | ||
context: Context) : Scenario(config, context) { | ||
init { | ||
config.setAutoCaptureSessions(false) | ||
} | ||
|
||
override fun run() { | ||
super.run() | ||
val client = Bugsnag.getClient() | ||
val thread = HandlerThread("HandlerThread") | ||
thread.start() | ||
|
||
Handler(thread.looper).post { | ||
// send 1st exception which should include session info | ||
client.startSession() | ||
client.notifyBlocking(generateException()) | ||
|
||
// send 2nd exception which should not include session info | ||
client.stopSession() | ||
client.notifyBlocking(generateException()) | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
Feature: Stopping and resuming sessions | ||
|
||
Scenario: When a session is stopped the error has no session information | ||
When I run "StoppedSessionScenario" | ||
Then I should receive 3 requests | ||
And the request 0 is valid for the session tracking API | ||
And the request 1 is valid for the error reporting API | ||
And the request 2 is valid for the error reporting API | ||
And the payload field "events.0.session" is not null for request 1 | ||
And the payload field "events.0.session" is null for request 2 | ||
|
||
Scenario: When a session is resumed the error uses the previous session information | ||
When I run "ResumedSessionScenario" | ||
Then I should receive 3 requests | ||
And the request 0 is valid for the session tracking API | ||
And the request 1 is valid for the error reporting API | ||
And the request 2 is valid for the error reporting API | ||
And the payload field "events.0.session.events.handled" equals 1 for request 1 | ||
And the payload field "events.0.session.events.handled" equals 2 for request 2 | ||
And the payload field "events.0.session.id" of request 1 equals the payload field "events.0.session.id" of request 2 | ||
And the payload field "events.0.session.startedAt" of request 1 equals the payload field "events.0.session.startedAt" of request 2 | ||
|
||
Scenario: When a new session is started the error uses different session information | ||
When I run "NewSessionScenario" | ||
Then I should receive 4 requests | ||
And the request 0 is valid for the session tracking API | ||
And the request 1 is valid for the error reporting API | ||
And the request 2 is valid for the session tracking API | ||
And the request 3 is valid for the error reporting API | ||
And the payload field "events.0.session.events.handled" equals 1 for request 1 | ||
And the payload field "events.0.session.events.handled" equals 1 for request 3 | ||
And the payload field "events.0.session.id" of request 1 does not equal the payload field "events.0.session.id" of request 3 |