1
0
Fork 0

Adding Profession Import (without specified character)

This commit is contained in:
Henrik Hautakoski 2021-09-01 15:17:00 +02:00
parent aa2b27bc50
commit 3692fcc485
4 changed files with 152 additions and 0 deletions

View file

@ -0,0 +1,28 @@
<?php
namespace App\Http\Controllers;
use App\Http\Requests\CharacterProfessionImportRequest;
use App\Jobs\ImportProfession;
class ProfessionController extends Controller
{
public function create()
{
return view('profession.create');
}
public function store(CharacterProfessionImportRequest $request)
{
$request->validated();
$data = json_decode($request->input('data'));
try {
ImportProfession::dispatch($data, $request->user());
} catch(\App\ProfessionImport\Exception $e) {
return redirect()->back()->with('error', $e->getMessage());
}
return redirect()->back()->with('success', 'Profession imported!');
}
}

View file

@ -0,0 +1,29 @@
<x-layout name="app">
<x-slot name="title">
<div class="flex">
{{ __('Import Profession') }}
</div>
</x-slot>
<div class="p-4">
<p class="text-center">
<strong>{{ __("Important") }}!</strong>
{{ __('Download this') }}
<x-link href="https://www.curseforge.com/wow/addons/professions-exporter" target="_blank">{{ __('addon') }}</x-link>
{{ __('to generate the import string') }}
</p>
<x-form action="{{ route('profession.store') }}">
<div class="mb-2">
<x-form.label for="data">{{ __('Import string') }}</x-form.label>
<x-textarea class="h-64" name="data" />
</div>
<div class="mt-2">
<x-button element="input" type="submit" value="{{ __('Import') }}" />
</div>
</x-form>
</div>
</x-layout>

View file

@ -82,6 +82,12 @@ Route::prefix('items')->name('item.')->group(function () {
// ----------------------------
Route::middleware(['auth'])->group(function() {
// Profession
Route::prefix('profession')->name('profession.')->group(function() {
Route::get('/create', [ProfessionController::class, 'create'])->name('create');
Route::post('/', [ProfessionController::class, 'store'])->name('store');
});
Route::prefix('profile')->name('profile.')->group(function () {
Route::get('/', [ProfileController::class, 'index'])->name('index');
Route::get('/edit', [ProfileController::class, 'edit'])->name('edit');

View file

@ -0,0 +1,89 @@
<?php
namespace Tests\Feature;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Illuminate\Foundation\Testing\WithFaker;
use Tests\TestCase;
use App\Models\Profession;
use App\Models\Character;
use App\Models\User;
class ProfessionTest extends TestCase
{
use RefreshDatabase;
public function test_guest_is_not_allowed_to_create_profession()
{
$response = $this->get(route('profession.create'));
$response->assertRedirect(route('auth.login'));
}
public function test_user_is_allowed_to_create_profession()
{
$user = User::factory()->create();
$response = $this->actingAs($user)
->get(route('profession.create'));
$response->assertStatus(200); // OK
}
public function test_user_is_allowed_to_import_profession_for_their_own_character()
{
Profession::factory()->create(['name' => 'Influencer']);
$user = User::factory()->create();
$character = Character::factory()
->for($user)
->create(['name' => 'Rambone']);
$data = '{
"server":"Bigglesworth",
"player":"Rambone",
"guild":"First Blood",
"profession": {
"locale":"enUS",
"name":"Influencer",
"specializationId":null,
"specializationName":null,
"level":375,
"maxLevel":375,
"recipes": []
}
}';
$response = $this->actingAs($user)
->post(route('profession.store'), ['data' => $data]);
$response->assertSessionHas(['success' => "Profession imported!"]);
}
public function test_user_is_not_allowed_to_import_profession_for_someone_elses_character()
{
Profession::factory()->create(['name' => 'Alchemy']);
$user = User::factory()->create();
$character = Character::factory()->create(['name' => 'Angus']);
$data = '{
"server":"Deviate Delight",
"player":"Angus",
"guild":"Phoenix",
"profession": {
"locale":"enUS",
"name":"Alchemy",
"specializationId":null,
"specializationName":null,
"level":375,
"maxLevel":375,
"recipes": []
}
}';
$response = $this->actingAs($user)
->post(route('profession.store'), ['data' => $data]);
$response->assertSessionHas(['error' => 'Could not find character "Angus"']);
}
}