it_register_user_when_metered_billing_is_active

This commit is contained in:
Čarodej
2022-01-10 10:20:13 +01:00
parent 0d8f1b64a7
commit 26aa8b46df
7 changed files with 192 additions and 48 deletions

View File

@@ -5,7 +5,7 @@ use Tests\TestCase;
use App\Users\Models\User;
use Domain\Files\Models\File;
use Domain\Sharing\Models\Share;
use Illuminate\Support\Facades\DB;
use Domain\Settings\Models\Setting;
class MeteredBillingRestrictionsTest extends TestCase
{
@@ -13,8 +13,9 @@ class MeteredBillingRestrictionsTest extends TestCase
{
parent::setUp();
DB::table('settings')->insert([
Setting::updateOrCreate([
'name' => 'subscription_type',
], [
'value' => 'metered',
]);
}

View File

@@ -1,7 +1,6 @@
<?php
namespace Tests\App\Socialite;
use DB;
use Storage;
use Tests\TestCase;
use App\Users\Models\User;
@@ -15,7 +14,7 @@ class SocialiteTest extends TestCase
/**
* @test
*/
public function it_socialite_redirect()
public function socialite_redirect_user()
{
$response = $this->get('api/socialite/google/redirect');
@@ -25,19 +24,8 @@ class SocialiteTest extends TestCase
/**
* @test
*/
public function it_socialite_callback()
public function socialite_execute_provider_callback()
{
// Set default settings
DB::table('settings')->insert([
[
'name' => 'registration',
'value' => 1,
], [
'name' => 'storage_default',
'value' => 5,
],
]);
// Create fake image
$fakeImage = UploadedFile::fake()
->image('fake-avatar.jpg');

View File

@@ -9,30 +9,28 @@ use Domain\Settings\Models\Setting;
use Illuminate\Support\Facades\Password;
use App\Users\Notifications\ResetPassword;
use Illuminate\Auth\Notifications\VerifyEmail;
use VueFileManager\Subscription\Domain\Plans\Models\Plan;
class SignFlowTest extends TestCase
{
/**
* @test
*/
public function it_register_user()
public function it_create_user_from_register_form()
{
collect([
[
'name' => 'default_max_storage_amount',
'value' => 12,
],
[
'name' => 'registration',
'value' => 1,
],
[
'name' => 'user_verification',
'value' => 1,
],
[
'name' => 'default_max_storage_amount',
'value' => 10,
],
])->each(function ($setting) {
Setting::create([
'name' => $setting['name'],
Setting::updateOrCreate([
'name' => $setting['name'],
], [
'value' => $setting['value'],
]);
});
@@ -44,14 +42,17 @@ class SignFlowTest extends TestCase
'name' => 'John Doe',
])->assertStatus(201);
$this->assertDatabaseHas('users', [
'email' => 'john@doe.com',
'email_verified_at' => null,
])->assertDatabaseHas('user_settings', [
'name' => 'John Doe',
])->assertDatabaseHas('user_limitations', [
'max_storage_amount' => 12,
]);
$this
->assertDatabaseHas('users', [
'email' => 'john@doe.com',
'email_verified_at' => null,
])
->assertDatabaseHas('user_settings', [
'name' => 'John Doe',
])
->assertDatabaseHas('user_limitations', [
'max_storage_amount' => 10,
]);
Storage::disk('local')
->assertExists('files/' . User::first()->id);
@@ -59,13 +60,60 @@ class SignFlowTest extends TestCase
Notification::assertTimesSent(1, VerifyEmail::class);
}
/**
* @test
*/
public function it_register_user_when_metered_billing_is_active()
{
// Seed default settings
Setting::updateOrCreate([
'name' => 'subscription_type',
], [
'value' => 'metered',
]);
// Create metered plan
$plan = Plan::factory()
->create([
'status' => 'active',
'type' => 'metered',
'currency' => 'USD',
]);
$this->postJson('api/register', [
'email' => 'john@doe.com',
'password' => 'SecretPassword',
'password_confirmation' => 'SecretPassword',
'name' => 'John Doe',
])->assertStatus(201);
$this
->assertDatabaseHas('users', [
'email' => 'john@doe.com',
])
->assertDatabaseHas('subscriptions', [
'status' => 'active',
'name' => $plan->name,
'ends_at' => null,
'renews_at' => now()->addDays(config('subscription.metered_billing.settlement_period')),
])
->assertDatabaseHas('balances', [
'currency' => 'USD',
'amount' => 0,
])
->assertDatabaseHas('user_settings', [
'name' => 'John Doe',
]);
}
/**
* @test
*/
public function it_try_register_when_registration_is_disabled()
{
Setting::create([
Setting::updateOrCreate([
'name' => 'registration',
], [
'value' => 0,
]);