mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-11-03 20:27:33 -05:00 
			
		
		
		
	* Fix for CORs error where file download were being prevented by headers * Fixes for CORs and File downloads * give contextual error messages for invalid route actions * Clean up LoginController for OAuth Testing * Quote Actions * Invoice and Quote Actions * Fix for client currency
		
			
				
	
	
		
			97 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace Tests\Feature;
 | 
						|
 | 
						|
use App\Jobs\Account\CreateAccount;
 | 
						|
use App\Models\Account;
 | 
						|
use App\Models\Client;
 | 
						|
use App\Models\User;
 | 
						|
use App\Utils\Traits\UserSessionAttributes;
 | 
						|
use Faker\Factory;
 | 
						|
use Illuminate\Database\Eloquent\Model;
 | 
						|
use Illuminate\Foundation\Testing\DatabaseTransactions;
 | 
						|
use Illuminate\Foundation\Testing\RefreshDatabase;
 | 
						|
use Illuminate\Foundation\Testing\WithFaker;
 | 
						|
use Illuminate\Http\Request;
 | 
						|
use Illuminate\Support\Facades\Session;
 | 
						|
use Tests\TestCase;
 | 
						|
 | 
						|
/**
 | 
						|
 * @test
 | 
						|
 * @covers App\Http\Controllers\AccountController
 | 
						|
 */
 | 
						|
 | 
						|
class AccountTest extends TestCase
 | 
						|
{
 | 
						|
    //use DatabaseTransactions;
 | 
						|
 | 
						|
    public function setUp() :void
 | 
						|
    {
 | 
						|
        parent::setUp();
 | 
						|
 | 
						|
        Session::start();
 | 
						|
 | 
						|
        $this->faker = \Faker\Factory::create();
 | 
						|
 | 
						|
        Model::reguard();
 | 
						|
    }
 | 
						|
 | 
						|
    // public function testAccountCreation()
 | 
						|
    // {
 | 
						|
    //     $data = [
 | 
						|
    //         'first_name' => $this->faker->firstName,
 | 
						|
    //         'last_name' => $this->faker->lastName,
 | 
						|
    //         'name' => $this->faker->company,
 | 
						|
    //         'email' => $this->faker->unique()->safeEmail,
 | 
						|
    //         'password' => 'ALongAndBrilliantPassword123',
 | 
						|
    //         '_token' => csrf_token(),
 | 
						|
    //         'privacy_policy' => 1,
 | 
						|
    //         'terms_of_service' => 1
 | 
						|
    //     ];
 | 
						|
 | 
						|
    //     try {
 | 
						|
 | 
						|
    //     $response = $this->post('/signup', $data, ['X-API-SECRET' => 'password']);
 | 
						|
 | 
						|
    //     }
 | 
						|
    //     catch(ValidationException $e) {
 | 
						|
 | 
						|
    //         $message = json_decode($e->validator->getMessageBag(),1);
 | 
						|
 | 
						|
    //         \Log::error($message);
 | 
						|
    //     }
 | 
						|
    //     finally                 {
 | 
						|
    //         $response->assertStatus(200);
 | 
						|
    //     }
 | 
						|
 | 
						|
    //     $response->assertStatus(200);
 | 
						|
        
 | 
						|
 | 
						|
    // }
 | 
						|
 | 
						|
    public function testApiAccountCreation()
 | 
						|
    {
 | 
						|
        $data = [
 | 
						|
            'first_name' => $this->faker->firstName,
 | 
						|
            'last_name' => $this->faker->lastName,
 | 
						|
            'name' => $this->faker->company,
 | 
						|
            'email' => $this->faker->unique()->safeEmail,
 | 
						|
            'password' => 'ALongAndBrilliantPassword123',
 | 
						|
            'privacy_policy' => 1,
 | 
						|
            'terms_of_service' => 1
 | 
						|
        ];
 | 
						|
 | 
						|
 | 
						|
        $response = $this->withHeaders([
 | 
						|
                'X-API-SECRET' => config('ninja.api_secret'),
 | 
						|
            ])->post('/api/v1/signup?include=account', $data);
 | 
						|
 | 
						|
        $response->assertStatus(200);
 | 
						|
          
 | 
						|
    
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
 | 
						|
}
 |