Adds transactional outbox and email verification
Implements outbox pattern for reliable message delivery Adds email verification flow with Postmark integration Enhances account registration with secure token generation Introduces background processing for asynchronous email sending Implements database-level notification mechanism for message processing
This commit is contained in:
parent
88812177a9
commit
54b057886c
35 changed files with 1174 additions and 358 deletions
|
|
@ -1,31 +1,34 @@
|
|||
using LightBDD.Framework;
|
||||
using LightBDD.Framework.Scenarios;
|
||||
using LightBDD.MsTest3;
|
||||
|
||||
namespace PlanTempus.X.BDD.Scenarios;
|
||||
|
||||
[TestClass]
|
||||
public partial class AccountRegistrationSpecs : FeatureFixtures.AccountRegistrationSpecs
|
||||
{
|
||||
[Scenario]
|
||||
[TestMethod]
|
||||
public async Task Successful_account_registration_with_valid_email()
|
||||
{
|
||||
await Runner.RunScenarioAsync(
|
||||
_ => Given_no_account_exists_with_email("test@example.com"),
|
||||
_ => When_I_submit_registration_with_email_and_password("test@example.com", "TestPassword123!"),
|
||||
_ => Then_a_new_account_should_be_created_with_email_and_confirmation_status("test@example.com", false),
|
||||
_ => Then_a_confirmation_email_should_be_sent()
|
||||
);
|
||||
}
|
||||
[Scenario]
|
||||
[TestMethod]
|
||||
public async Task Successful_account_registration_with_valid_email()
|
||||
{
|
||||
await Runner.RunScenarioAsync(
|
||||
_ => Given_a_unique_email_address(),
|
||||
_ => When_I_submit_registration_with_valid_credentials(),
|
||||
_ => Then_the_account_should_be_created_successfully()
|
||||
);
|
||||
}
|
||||
|
||||
[Scenario]
|
||||
[TestMethod]
|
||||
public async Task Reject_duplicate_email_registration()
|
||||
{
|
||||
await Runner.RunScenarioAsync(
|
||||
_ => Given_an_account_already_exists_with_email("existing@example.com"),
|
||||
_ => When_I_submit_registration_with_email("existing@example.com"),
|
||||
_ => Then_registration_should_fail_with_error("Email already exists")
|
||||
);
|
||||
}
|
||||
[Scenario]
|
||||
[TestMethod]
|
||||
public async Task Reject_duplicate_email_registration()
|
||||
{
|
||||
// Use a unique email for this test to avoid conflicts with other test runs
|
||||
var uniqueEmail = $"duplicate_{Guid.NewGuid():N}@test.example.com";
|
||||
|
||||
await Runner.RunScenarioAsync(
|
||||
_ => Given_an_account_already_exists_with_email(uniqueEmail),
|
||||
_ => When_I_try_to_register_with_the_same_email(),
|
||||
_ => Then_registration_should_fail_with_duplicate_email_error()
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue