mirror of
https://github.com/HolgerHatGarKeineNode/einundzwanzig-nostr.git
synced 2026-04-15 20:18:42 +00:00
🔧 Adjust Livewire tests to pass ProjectProposal model directly, refine edit form behavior, and test admin-specific functionality.
This commit is contained in:
@@ -22,16 +22,17 @@ beforeEach(function () {
|
|||||||
'event_id' => 'test_event_'.Str::random(40),
|
'event_id' => 'test_event_'.Str::random(40),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$this->project = ProjectProposal::factory()->create([
|
$this->project = ProjectProposal::query()->create([
|
||||||
'einundzwanzig_pleb_id' => $this->pleb->id,
|
'einundzwanzig_pleb_id' => $this->pleb->id,
|
||||||
'name' => 'Original Project',
|
'name' => 'Original Project',
|
||||||
'description' => 'Original Description',
|
'description' => 'Original Description',
|
||||||
'support_in_sats' => 21000,
|
'support_in_sats' => 21000,
|
||||||
'website' => 'https://example.com',
|
'website' => 'https://original.example.com',
|
||||||
|
'accepted' => false,
|
||||||
|
'sats_paid' => 0,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
// Get board member pubkeys from config
|
// Get board member pubkeys from config
|
||||||
$boardPubkeys = config('einundzwanzig.config.current_board', []);
|
|
||||||
$this->boardMember = EinundzwanzigPleb::query()->create([
|
$this->boardMember = EinundzwanzigPleb::query()->create([
|
||||||
'pubkey' => 'board_pubkey_'.Str::random(20),
|
'pubkey' => 'board_pubkey_'.Str::random(20),
|
||||||
'npub' => 'board_npub_'.Str::random(20),
|
'npub' => 'board_npub_'.Str::random(20),
|
||||||
@@ -45,8 +46,9 @@ beforeEach(function () {
|
|||||||
it('renders edit form for authorized project owners', function () {
|
it('renders edit form for authorized project owners', function () {
|
||||||
NostrAuth::login($this->pleb->pubkey);
|
NostrAuth::login($this->pleb->pubkey);
|
||||||
|
|
||||||
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project->slug])
|
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project])
|
||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
|
->assertSee('Projektförderung bearbeiten')
|
||||||
->assertSet('form.name', $this->project->name)
|
->assertSet('form.name', $this->project->name)
|
||||||
->assertSet('form.description', $this->project->description);
|
->assertSet('form.description', $this->project->description);
|
||||||
});
|
});
|
||||||
@@ -54,8 +56,9 @@ it('renders edit form for authorized project owners', function () {
|
|||||||
it('renders edit form for board members', function () {
|
it('renders edit form for board members', function () {
|
||||||
NostrAuth::login($this->boardMember->pubkey);
|
NostrAuth::login($this->boardMember->pubkey);
|
||||||
|
|
||||||
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project->slug])
|
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project])
|
||||||
->assertStatus(200);
|
->assertStatus(200)
|
||||||
|
->assertSee('Projektförderung bearbeiten');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('does not render edit form for unauthorized users', function () {
|
it('does not render edit form for unauthorized users', function () {
|
||||||
@@ -67,14 +70,14 @@ it('does not render edit form for unauthorized users', function () {
|
|||||||
|
|
||||||
NostrAuth::login($unauthorizedPleb->pubkey);
|
NostrAuth::login($unauthorizedPleb->pubkey);
|
||||||
|
|
||||||
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project->slug])
|
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project])
|
||||||
->assertSet('isAllowed', false);
|
->assertSet('isAllowed', false);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('validates required name field', function () {
|
it('validates required name field', function () {
|
||||||
NostrAuth::login($this->pleb->pubkey);
|
NostrAuth::login($this->pleb->pubkey);
|
||||||
|
|
||||||
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project->slug])
|
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project])
|
||||||
->set('form.name', '')
|
->set('form.name', '')
|
||||||
->set('form.description', 'Test description')
|
->set('form.description', 'Test description')
|
||||||
->call('update')
|
->call('update')
|
||||||
@@ -84,7 +87,7 @@ it('validates required name field', function () {
|
|||||||
it('validates required description field', function () {
|
it('validates required description field', function () {
|
||||||
NostrAuth::login($this->pleb->pubkey);
|
NostrAuth::login($this->pleb->pubkey);
|
||||||
|
|
||||||
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project->slug])
|
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project])
|
||||||
->set('form.name', 'Test Project')
|
->set('form.name', 'Test Project')
|
||||||
->set('form.description', '')
|
->set('form.description', '')
|
||||||
->call('update')
|
->call('update')
|
||||||
@@ -94,11 +97,9 @@ it('validates required description field', function () {
|
|||||||
it('updates project proposal successfully', function () {
|
it('updates project proposal successfully', function () {
|
||||||
NostrAuth::login($this->pleb->pubkey);
|
NostrAuth::login($this->pleb->pubkey);
|
||||||
|
|
||||||
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project->slug])
|
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project])
|
||||||
->set('form.name', 'Updated Name')
|
->set('form.name', 'Updated Name')
|
||||||
->set('form.description', 'Updated Description')
|
->set('form.description', 'Updated Description')
|
||||||
->set('form.support_in_sats', 42000)
|
|
||||||
->set('form.website', 'https://updated.com')
|
|
||||||
->call('update')
|
->call('update')
|
||||||
->assertHasNoErrors();
|
->assertHasNoErrors();
|
||||||
|
|
||||||
@@ -107,14 +108,42 @@ it('updates project proposal successfully', function () {
|
|||||||
expect($this->project->description)->toBe('Updated Description');
|
expect($this->project->description)->toBe('Updated Description');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('saves accepted and sats_paid when admin updates', function () {
|
||||||
|
NostrAuth::login($this->boardMember->pubkey);
|
||||||
|
|
||||||
|
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project])
|
||||||
|
->assertSet('isAdmin', true)
|
||||||
|
->set('form.accepted', true)
|
||||||
|
->set('form.sats_paid', 50000)
|
||||||
|
->call('update')
|
||||||
|
->assertHasNoErrors();
|
||||||
|
|
||||||
|
$this->project->refresh();
|
||||||
|
expect($this->project->accepted)->toBeTrue();
|
||||||
|
expect($this->project->sats_paid)->toBe(50000);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('does not allow non-admin to change accepted and sats_paid', function () {
|
||||||
|
NostrAuth::login($this->pleb->pubkey);
|
||||||
|
|
||||||
|
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project])
|
||||||
|
->assertSet('isAdmin', false)
|
||||||
|
->set('form.accepted', true)
|
||||||
|
->set('form.sats_paid', 99999)
|
||||||
|
->call('update')
|
||||||
|
->assertHasNoErrors();
|
||||||
|
|
||||||
|
$this->project->refresh();
|
||||||
|
expect($this->project->accepted)->toBeFalse();
|
||||||
|
expect($this->project->sats_paid)->toBe(0);
|
||||||
|
});
|
||||||
|
|
||||||
it('disables update button during save', function () {
|
it('disables update button during save', function () {
|
||||||
NostrAuth::login($this->pleb->pubkey);
|
NostrAuth::login($this->pleb->pubkey);
|
||||||
|
|
||||||
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project->slug])
|
Livewire::test('association.project-support.form.edit', ['projectProposal' => $this->project])
|
||||||
->set('form.name', 'Test')
|
->set('form.name', 'Test')
|
||||||
->set('form.description', 'Test')
|
->set('form.description', 'Test')
|
||||||
->set('form.support_in_sats', 21000)
|
|
||||||
->set('form.website', 'https://example.com')
|
|
||||||
->call('update')
|
->call('update')
|
||||||
->assertSeeHtml('wire:loading');
|
->assertSeeHtml('wire:loading');
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user