-
Notifications
You must be signed in to change notification settings - Fork 30
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
31 changed files
with
1,276 additions
and
323 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
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
23 changes: 23 additions & 0 deletions
23
requirements/emailController/addNonHgnEmailSubscription.md
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,23 @@ | ||
# Add Non-HGN Email Subscription Function | ||
|
||
## Negative Cases | ||
|
||
1. ❌ **Returns error 400 if `email` field is missing from the request** | ||
- Ensures that the function checks for the presence of the `email` field in the request body and responds with a `400` status code if it's missing. | ||
|
||
2. ❌ **Returns error 400 if the provided `email` already exists in the subscription list** | ||
- This case checks that the function responds with a `400` status code and a message indicating that the email is already subscribed. | ||
|
||
3. ❌ **Returns error 500 if there is an internal error while checking the subscription list** | ||
- Covers scenarios where there's an issue querying the `EmailSubscriptionList` collection for the provided email (e.g., database connection issues). | ||
|
||
4. ❌ **Returns error 500 if there is an error sending the confirmation email** | ||
- This case handles any issues that occur while calling the `emailSender` function, such as network errors or service unavailability. | ||
|
||
## Positive Cases | ||
|
||
1. ❌ **Returns status 200 when a new email is successfully subscribed** | ||
- Ensures that the function successfully creates a JWT token, constructs the email, and sends the subscription confirmation email to the user. | ||
|
||
2. ❌ **Successfully sends a confirmation email containing the correct link** | ||
- Verifies that the generated JWT token is correctly included in the confirmation link sent to the user in the email body. |
18 changes: 18 additions & 0 deletions
18
requirements/emailController/confirmNonHgnEmailSubscription.md
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,18 @@ | ||
# Confirm Non-HGN Email Subscription Function Tests | ||
|
||
## Negative Cases | ||
1. ✅ **Returns error 400 if `token` field is missing from the request** | ||
- (Test: `should return 400 if token is not provided`) | ||
|
||
2. ✅ **Returns error 401 if the provided `token` is invalid or expired** | ||
- (Test: `should return 401 if token is invalid`) | ||
|
||
3. ✅ **Returns error 400 if the decoded `token` does not contain a valid `email` field** | ||
- (Test: `should return 400 if email is missing from payload`) | ||
|
||
4. ❌ **Returns error 500 if there is an internal error while saving the new email subscription** | ||
|
||
## Positive Cases | ||
1. ❌ **Returns status 200 when a new email is successfully subscribed** | ||
|
||
2. ❌ **Returns status 200 if the email is already subscribed (duplicate email)** |
10 changes: 10 additions & 0 deletions
10
requirements/emailController/removeNonHgnEmailSubscription.md
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,10 @@ | ||
# Remove Non-HGN Email Subscription Function Tests | ||
|
||
## Negative Cases | ||
1. ✅ **Returns error 400 if `email` field is missing from the request** | ||
- (Test: `should return 400 if email is missing`) | ||
|
||
2. ❌ **Returns error 500 if there is an internal error while deleting the email subscription** | ||
|
||
## Positive Cases | ||
1. ❌ **Returns status 200 when an email is successfully unsubscribed** |
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,10 @@ | ||
# Send Email Function | ||
|
||
## Negative Cases | ||
|
||
1. ❌ **Returns error 400 if `to`, `subject`, or `html` fields are missing from the request** | ||
2. ❌ **Returns error 500 if there is an internal error while sending the email** | ||
|
||
## Positive Cases | ||
|
||
1. ✅ **Returns status 200 when email is successfully sent with `to`, `subject`, and `html` fields provided** |
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,26 @@ | ||
# Send Email to All Function | ||
|
||
## Negative Cases | ||
|
||
1. ❌ **Returns error 400 if `subject` or `html` fields are missing from the request** | ||
- The request should be rejected if either the `subject` or `html` content is not provided in the request body. | ||
|
||
2. ❌ **Returns error 500 if there is an internal error while fetching users** | ||
- This case covers scenarios where there's an error fetching users from the `userProfile` collection (e.g., database connection issues). | ||
|
||
3. ❌ **Returns error 500 if there is an internal error while fetching the subscription list** | ||
- This case covers scenarios where there's an error fetching emails from the `EmailSubcriptionList` collection. | ||
|
||
4. ❌ **Returns error 500 if there is an error sending emails** | ||
- This case handles any issues that occur while calling the `emailSender` function, such as network errors or service unavailability. | ||
|
||
## Positive Cases | ||
|
||
1. ❌ **Returns status 200 when emails are successfully sent to all active users** | ||
- Ensures that the function sends emails correctly to all users meeting the criteria (`isActive` and `EmailSubcriptionList`). | ||
|
||
2. ❌ **Returns status 200 when emails are successfully sent to all users in the subscription list** | ||
- Verifies that the function sends emails to all users in the `EmailSubcriptionList`, including the unsubscribe link in the email body. | ||
|
||
3. ❌ **Combines user and subscription list emails successfully** | ||
- Ensures that the function correctly sends emails to both active users and the subscription list without issues. |
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,20 @@ | ||
# Update Email Subscriptions Function | ||
|
||
## Negative Cases | ||
|
||
1. ❌ **Returns error 400 if `emailSubscriptions` field is missing from the request** | ||
- This ensures that the function checks for the presence of the `emailSubscriptions` field in the request body and responds with a `400` status code if it's missing. | ||
|
||
2. ❌ **Returns error 400 if `email` field is missing from the requestor object** | ||
- Ensures that the function requires an `email` field within the `requestor` object in the request body and returns `400` if it's absent. | ||
|
||
3. ❌ **Returns error 404 if the user with the provided `email` is not found** | ||
- This checks that the function correctly handles cases where no user exists with the given `email` and responds with a `404` status code. | ||
|
||
4. ✅ **Returns error 500 if there is an internal error while updating the user profile** | ||
- Covers scenarios where there's a database error while updating the user's email subscriptions. | ||
|
||
## Positive Cases | ||
|
||
1. ❌ **Returns status 200 and the updated user when email subscriptions are successfully updated** | ||
- Ensures that the function updates the `emailSubscriptions` field for the user and returns the updated user document along with a `200` status code. |
14 changes: 14 additions & 0 deletions
14
requirements/popUpEditorController/createPopPopupEditor.md
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,14 @@ | ||
Check mark: ✅ | ||
Cross Mark: ❌ | ||
|
||
# createPopPopupEditor Function | ||
|
||
> ### Positive case | ||
> 1. ✅ Should return 201 and the new pop-up editor on success | ||
> ### Negative case | ||
> 1. ✅ Should return 403 if user does not have permission to create a pop-up editor | ||
> 2. ✅ Should return 400 if the request body is missing required fields | ||
> 3. ✅ Should return 500 if there is an error saving the new pop-up editor to the database |
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,10 @@ | ||
Check mark: ✅ | ||
Cross Mark: ❌ | ||
|
||
# getAllPopupEditors Function | ||
|
||
> ## Positive case | ||
> 1. ✅ Should return 200 and all pop-up editors on success | ||
> ## Negative case | ||
> 1. ✅ Should return 404 if there is an error retrieving the pop-up editors from the database |
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,10 @@ | ||
Check mark: ✅ | ||
Cross Mark: ❌ | ||
|
||
# getPopupEditorById Function | ||
|
||
> ## Positive case | ||
> 1. ✅ Should return 200 and the pop-up editor on success | ||
> ## Negative case | ||
> 1. ✅ Should return 404 if the pop-up editor is not found |
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,11 @@ | ||
Check mark: ✅ | ||
Cross Mark: ❌ | ||
|
||
# updatePopupEditor Function | ||
|
||
> ## Positive case | ||
> 1. ✅ Should return 200 and the updated pop-up editor on success | ||
|
||
> ## Negative case | ||
> 1. ✅ Should return 404 if the pop-up editor is not found |
Oops, something went wrong.