mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-28 19:10:40 +00:00
added it_get_user_subscription test
This commit is contained in:
@@ -47,25 +47,25 @@ class SubscriptionController extends Controller
|
|||||||
/**
|
/**
|
||||||
* Get user subscription detail
|
* Get user subscription detail
|
||||||
*
|
*
|
||||||
* @return array
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function show()
|
public function show()
|
||||||
{
|
{
|
||||||
$user = Auth::user();
|
$user = User::find(Auth::id());
|
||||||
|
|
||||||
if (!$user->subscription('main')) {
|
if (!$user->subscription('main')) {
|
||||||
return abort(204, 'User don\'t have any subscription');
|
return abort(204, 'User don\'t have any subscription');
|
||||||
}
|
}
|
||||||
|
|
||||||
$slug_user_subscription = 'subscription-user-' . $user->id;
|
$slug = 'subscription-user-' . $user->id;
|
||||||
|
|
||||||
if (Cache::has($slug_user_subscription)) {
|
if (Cache::has($slug)) {
|
||||||
return Cache::get($slug_user_subscription);
|
return Cache::get($slug);
|
||||||
}
|
}
|
||||||
|
|
||||||
return Cache::rememberForever($slug_user_subscription, function () {
|
return Cache::rememberForever($slug, function () use ($user) {
|
||||||
return new UserSubscription(
|
return new UserSubscription(
|
||||||
Auth::user()
|
$user
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ namespace Tests\Feature;
|
|||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
use App\Models\UserSettings;
|
use App\Models\UserSettings;
|
||||||
use App\Services\StripeService;
|
use App\Services\StripeService;
|
||||||
|
use Carbon\Carbon;
|
||||||
use Illuminate\Foundation\Testing\DatabaseMigrations;
|
use Illuminate\Foundation\Testing\DatabaseMigrations;
|
||||||
use Illuminate\Support\Facades\Http;
|
use Illuminate\Support\Facades\Http;
|
||||||
use Illuminate\Support\Facades\Storage;
|
use Illuminate\Support\Facades\Storage;
|
||||||
@@ -57,7 +58,7 @@ class SubscriptionTest extends TestCase
|
|||||||
'billing_city' => 'Christianfort',
|
'billing_city' => 'Christianfort',
|
||||||
'billing_country' => 'SK',
|
'billing_country' => 'SK',
|
||||||
'billing_name' => 'Heidi Romaguera PhD',
|
'billing_name' => 'Heidi Romaguera PhD',
|
||||||
'billing_phone_number' => '',
|
'billing_phone_number' => '+421',
|
||||||
'billing_postal_code' => '59445',
|
'billing_postal_code' => '59445',
|
||||||
'billing_state' => 'SK',
|
'billing_state' => 'SK',
|
||||||
];
|
];
|
||||||
@@ -138,7 +139,7 @@ class SubscriptionTest extends TestCase
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
*
|
||||||
*/
|
*/
|
||||||
public function it_resume_subscription()
|
public function it_resume_subscription()
|
||||||
{
|
{
|
||||||
@@ -165,4 +166,44 @@ class SubscriptionTest extends TestCase
|
|||||||
'ends_at' => null
|
'ends_at' => null
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_get_user_subscription()
|
||||||
|
{
|
||||||
|
$user = User::factory(User::class)
|
||||||
|
->create($this->user);
|
||||||
|
|
||||||
|
Sanctum::actingAs($user);
|
||||||
|
|
||||||
|
$this->postJson('/api/user/subscription/upgrade', [
|
||||||
|
'billing' => $this->billing,
|
||||||
|
'plan' => $this->plan,
|
||||||
|
'payment' => [
|
||||||
|
'type' => 'stripe',
|
||||||
|
],
|
||||||
|
])->assertStatus(204);
|
||||||
|
|
||||||
|
$this->getJson('/api/user/subscription')
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertExactJson([
|
||||||
|
"data" => [
|
||||||
|
"id" => "business-pack",
|
||||||
|
"type" => "subscription",
|
||||||
|
"attributes" => [
|
||||||
|
"incomplete" => false,
|
||||||
|
"active" => true,
|
||||||
|
"canceled" => false,
|
||||||
|
"name" => "Business Packs",
|
||||||
|
"capacity" => 1000,
|
||||||
|
"capacity_formatted" => "1TB",
|
||||||
|
"slug" => "business-pack",
|
||||||
|
"canceled_at" => format_date(Carbon::now(), '%d. %B. %Y'),
|
||||||
|
"created_at" => format_date(Carbon::now(), '%d. %B. %Y'),
|
||||||
|
"ends_at" => format_date(Carbon::now()->addMonth(), '%d. %B. %Y'),
|
||||||
|
]
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user