mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-25 17:32:54 -04:00 
			
		
		
		
	Test for Wave Invoice Import
This commit is contained in:
		
							parent
							
								
									8b4f109f7d
								
							
						
					
					
						commit
						ac09ffff32
					
				| @ -182,8 +182,6 @@ class BaseImport | ||||
| 
 | ||||
| 			} catch (\Exception $ex) { | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 				if ($ex instanceof ImportException) { | ||||
| 					$message = $ex->getMessage(); | ||||
| 				} else { | ||||
| @ -199,7 +197,7 @@ class BaseImport | ||||
| 
 | ||||
| 		} | ||||
| 
 | ||||
| 			return $count; | ||||
| 		return $count; | ||||
| 	} | ||||
| 
 | ||||
| 	public function ingestInvoices($invoices, $invoice_number_key) | ||||
| @ -220,8 +218,10 @@ class BaseImport | ||||
| 		$invoices = $this->groupInvoices($invoices, $invoice_number_key); | ||||
| 
 | ||||
| 		foreach ($invoices as $raw_invoice) { | ||||
| 			nlog($raw_invoice); | ||||
| 			try { | ||||
| 				$invoice_data = $invoice_transformer->transform($raw_invoice); | ||||
| 				nlog($invoice_data); | ||||
| 				$invoice_data['line_items'] = $this->cleanItems( | ||||
| 					$invoice_data['line_items'] ?? [] | ||||
| 				); | ||||
|  | ||||
| @ -13,10 +13,14 @@ | ||||
| namespace App\Import\Providers; | ||||
| 
 | ||||
| use App\Factory\ClientFactory; | ||||
| use App\Factory\InvoiceFactory; | ||||
| use App\Http\Requests\Client\StoreClientRequest; | ||||
| use App\Http\Requests\Invoice\StoreInvoiceRequest; | ||||
| use App\Import\Transformer\Wave\ClientTransformer; | ||||
| use App\Import\Transformer\Wave\InvoiceTransformer; | ||||
| use App\Models\Client; | ||||
| use App\Repositories\ClientRepository; | ||||
| use App\Repositories\InvoiceRepository; | ||||
| 
 | ||||
| class Wave extends BaseImport implements ImportInterface | ||||
| { | ||||
| @ -28,8 +32,8 @@ class Wave extends BaseImport implements ImportInterface | ||||
|         if ( | ||||
|             in_array($entity, [ | ||||
|                 'client', | ||||
|                 'invoice', | ||||
|                 // 'product',
 | ||||
|                 // 'invoice',
 | ||||
|                 // 'payment',
 | ||||
|                 // 'vendor',
 | ||||
|                 // 'expense',
 | ||||
| @ -48,10 +52,8 @@ class Wave extends BaseImport implements ImportInterface | ||||
|         $entity_type = 'client'; | ||||
| 
 | ||||
|         $data = $this->getCsvData($entity_type); | ||||
| // nlog($data);
 | ||||
| 
 | ||||
|         $data = $this->preTransform($data, $entity_type); | ||||
| // nlog($data);
 | ||||
| 
 | ||||
|         if (empty($data)) { | ||||
|             $this->entity_count['clients'] = 0; | ||||
| @ -71,15 +73,52 @@ class Wave extends BaseImport implements ImportInterface | ||||
| 
 | ||||
|         $this->entity_count['clients'] = $client_count; | ||||
| 
 | ||||
|         nlog($this->entity_count); | ||||
|         nlog($this->error_array); | ||||
|     } | ||||
| 
 | ||||
|     public function transform(array $data){} | ||||
| 
 | ||||
|     public function product() {} | ||||
|     public function product() { | ||||
| 
 | ||||
|     public function invoice() {} | ||||
|         //done automatically inside the invoice() method as we need to harvest the products from the line items
 | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     public function invoice() { | ||||
| 
 | ||||
|         //make sure we update and create products with wave
 | ||||
|         $initial_update_products_value = $this->company->update_products;  | ||||
|         $this->company->update_products = true; | ||||
| 
 | ||||
|         $this->company->save(); | ||||
| 
 | ||||
|         $entity_type = 'invoice'; | ||||
| 
 | ||||
|         $data = $this->getCsvData($entity_type); | ||||
| nlog($data); | ||||
| 
 | ||||
|         $data = $this->preTransform($data, $entity_type); | ||||
| nlog($data); | ||||
|         if (empty($data)) { | ||||
|             $this->entity_count['invoices'] = 0; | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         $this->request_name = StoreInvoiceRequest::class; | ||||
|         $this->repository_name = InvoiceRepository::class; | ||||
|         $this->factory_name = InvoiceFactory::class; | ||||
| 
 | ||||
|         $this->repository = app()->make($this->repository_name); | ||||
|         $this->repository->import_mode = true; | ||||
| 
 | ||||
|         $this->transformer = new InvoiceTransformer($this->company); | ||||
| 
 | ||||
|         $invoice_count = $this->ingestInvoices($data, 'Invoice Number'); | ||||
| 
 | ||||
|         $this->entity_count['invoices'] = $invoice_count; | ||||
| 
 | ||||
|         $this->company->update_products = $initial_update_products_value; | ||||
|         $this->company->save();     | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     public function payment() {} | ||||
| 
 | ||||
| @ -87,4 +126,5 @@ class Wave extends BaseImport implements ImportInterface | ||||
| 
 | ||||
|     public function expense() {} | ||||
| 
 | ||||
|     public function transform(array $data){} | ||||
| } | ||||
|  | ||||
| @ -9,7 +9,7 @@ | ||||
|  * @license https://www.elastic.co/licensing/elastic-license | ||||
|  */ | ||||
| 
 | ||||
| namespace App\Import\Transformer\Waveaccounting; | ||||
| namespace App\Import\Transformer\Wave; | ||||
| 
 | ||||
| use App\Import\ImportException; | ||||
| use App\Import\Transformer\BaseTransformer; | ||||
|  | ||||
| @ -14,6 +14,8 @@ namespace Tests\Feature\Import\CSV; | ||||
| use App\Import\Providers\Wave; | ||||
| use App\Import\Transformer\BaseTransformer; | ||||
| use App\Models\Client; | ||||
| use App\Models\Invoice; | ||||
| use App\Models\Product; | ||||
| use App\Utils\Traits\MakesHash; | ||||
| use Illuminate\Foundation\Testing\DatabaseTransactions; | ||||
| use Illuminate\Routing\Middleware\ThrottleRequests; | ||||
| @ -120,6 +122,127 @@ class WaveTest extends TestCase | ||||
|          | ||||
|     } | ||||
| 
 | ||||
|     public function testInvoiceWaveImport() | ||||
|     { | ||||
|         //first import all the clients
 | ||||
| 
 | ||||
|                 $csv = file_get_contents( | ||||
|             base_path() . '/tests/Feature/Import/wave_clients.csv' | ||||
|         ); | ||||
|         $hash = Str::random(32); | ||||
| 
 | ||||
|         $column_map = [ | ||||
|             0 => 'customer_name', | ||||
|             1 => 'email', | ||||
|             2 => 'contact_first_name', | ||||
|             3 => 'contact_last_name', | ||||
|             4 => 'customer_currency', | ||||
|             5 => 'account_number', | ||||
|             6 => 'phone', | ||||
|             7 => 'fax', | ||||
|             8 => 'mobile', | ||||
|             9 => 'toll_free', | ||||
|             10 => 'website', | ||||
|             11 => 'country', | ||||
|             12 => 'province/state', | ||||
|             13 => 'address_line_1', | ||||
|             14 => 'address_line_2', | ||||
|             15 => 'city', | ||||
|             16 => 'postal_code/zip_code', | ||||
|             17 => 'shipping_address', | ||||
|             18 => 'ship-to_contact', | ||||
|             19 => 'ship-to_country', | ||||
|             20 => 'ship-to_province/state', | ||||
|             21 => 'ship-to_address_line_1', | ||||
|             22 => 'ship-to_address_line_2', | ||||
|             23 => 'ship-to_city', | ||||
|             24 => 'ship-to_postal_code/zip_code', | ||||
|             25 => 'ship-to_phone', | ||||
|             26 => 'delivery_instructions',         | ||||
|         ]; | ||||
| 
 | ||||
|         $data = [ | ||||
|             'hash' => $hash, | ||||
|             'column_map' => ['client' => ['mapping' => $column_map]], | ||||
|             'skip_header' => true, | ||||
|             'import_type' => 'waveaccounting', | ||||
|         ]; | ||||
| 
 | ||||
|         Cache::put($hash . '-client', base64_encode($csv), 360); | ||||
| 
 | ||||
|         $csv_importer = new Wave($data, $this->company); | ||||
| 
 | ||||
|         $count = $csv_importer->import('client'); | ||||
| 
 | ||||
|         //now import the invoices
 | ||||
| 
 | ||||
|         $csv = file_get_contents( | ||||
|             base_path() . '/tests/Feature/Import/wave_invoices.csv' | ||||
|         ); | ||||
|         $hash = Str::random(32); | ||||
| 
 | ||||
|         $column_map = [ | ||||
|             0 => 'Transaction ID', | ||||
|             1 => 'Transaction Date', | ||||
|             2 => 'Account Name', | ||||
|             3 => 'Transaction Description', | ||||
|             4 => 'Transaction Line Description', | ||||
|             5 => 'Amount (One column)', | ||||
|             6 => ' ', | ||||
|             7 => 'Debit Amount (Two Column Approach)', | ||||
|             8 => 'Credit Amount (Two Column Approach)', | ||||
|             9 => 'Other Accounts for this Transaction', | ||||
|             10 => 'Customer', | ||||
|             11 => 'Vendor', | ||||
|             12 => 'Invoice Number', | ||||
|             13 => 'Bill Number', | ||||
|             14 => 'Notes / Memo', | ||||
|             15 => 'Amount Before Sales Tax', | ||||
|             16 => 'Sales Tax Amount', | ||||
|             17 => 'Sales Tax Name', | ||||
|             18 => 'Transaction Date Added', | ||||
|             19 => 'Transaction Date Last Modified', | ||||
|             20 => 'Account Group', | ||||
|             21 => 'Account Type', | ||||
|             22 => 'Account ID',     | ||||
|         ]; | ||||
| 
 | ||||
|         $data = [ | ||||
|             'hash' => $hash, | ||||
|             'column_map' => ['invoice' => ['mapping' => $column_map]], | ||||
|             'skip_header' => true, | ||||
|             'import_type' => 'waveaccounting', | ||||
|         ]; | ||||
| 
 | ||||
|         Cache::put($hash . '-invoice', base64_encode($csv), 360); | ||||
| 
 | ||||
|         $csv_importer = new Wave($data, $this->company); | ||||
| 
 | ||||
|         $count = $csv_importer->import('invoice'); | ||||
| 
 | ||||
|         $base_transformer = new BaseTransformer($this->company); | ||||
| 
 | ||||
|         $this->assertTrue($base_transformer->hasInvoice("2")); | ||||
|         $this->assertTrue($base_transformer->hasInvoice("3")); | ||||
|         $this->assertTrue($base_transformer->hasInvoice("4")); | ||||
| 
 | ||||
|         $invoice_id = $base_transformer->getInvoiceId("4"); | ||||
|         $invoice = Invoice::find($invoice_id); | ||||
| 
 | ||||
|         $this->assertEquals(3500.41 , $invoice->amount); | ||||
|         $this->assertEquals(0 , $invoice->balance); | ||||
|         $this->assertEquals(2 , count($invoice->line_items)); | ||||
| 
 | ||||
|         $this->assertTrue($invoice->payments()->exists()); | ||||
|         $this->assertEquals(3500.41, $invoice->payments->first()->amount); | ||||
| 
 | ||||
|         $product = Product::where('notes', 'Lawn Service')->where('company_id', $this->company->id)->first(); | ||||
| 
 | ||||
| 
 | ||||
|         nlog(Product::all()->pluck('notes')); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     // public function testVendorCsvImport()
 | ||||
|     // {
 | ||||
|     //     $csv = file_get_contents(
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user