117 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| namespace nur\io\csv;
 | |
| 
 | |
| use nur\b\io\StringWriter;
 | |
| use nur\t\TestCase;
 | |
| 
 | |
| class CsvWriterTest extends TestCase {
 | |
|   function testWriter() {
 | |
|     $w = new StringWriter();
 | |
|     $writer = new CsvWriter($w);
 | |
|     $writer->writeAll([
 | |
|       ["nom" => "clain", "prenom" => "jephté", "age" => 45],
 | |
|       ["nom" => "enpion", "prenom" => "tarte", "age" => 36],
 | |
|       ["nom" => "cool", "prenom" => "plusieurs
 | |
| lignes", "age" => 15],
 | |
|     ]);
 | |
|     self::assertSame("nom,prenom,age
 | |
| clain,jephté,45
 | |
| enpion,tarte,36
 | |
| cool,\"plusieurs
 | |
| lignes\",15
 | |
| ", $w->getString());
 | |
|   }
 | |
| 
 | |
|   function testResource() {
 | |
|     $w = fopen("php://memory", "w+b");
 | |
|     $writer = new CsvWriter($w);
 | |
|     $writer->writeAll([
 | |
|       ["nom" => "clain", "prenom" => "jephté", "age" => 45],
 | |
|       ["nom" => "enpion", "prenom" => "tarte", "age" => 36],
 | |
|       ["nom" => "cool", "prenom" => "plusieurs
 | |
| lignes", "age" => 15],
 | |
|     ]);
 | |
|     rewind($w);
 | |
|     self::assertSame("nom,prenom,age
 | |
| clain,jephté,45
 | |
| enpion,tarte,36
 | |
| cool,\"plusieurs
 | |
| lignes\",15
 | |
| ", stream_get_contents($w));
 | |
|   }
 | |
| 
 | |
|   function testEmpty() {
 | |
|     $w = new StringWriter();
 | |
|     $writer = new CsvWriter($w);
 | |
|     $writer->writeAll([]);
 | |
|     self::assertSame("", $w->getString());
 | |
| 
 | |
|     $w = new StringWriter();
 | |
|     $writer = new CsvWriter($w);
 | |
|     $writer->setHeaders(["nom", "prenom", "age"]);
 | |
|     $writer->writeAll([]);
 | |
|     self::assertSame("nom,prenom,age\n", $w->getString());
 | |
|   }
 | |
| 
 | |
|   function testMappings() {
 | |
|     $rows = [
 | |
|       ["nom" => "clain", "prenom" => "jephte", "annees" => "45", "ville" => "sainte-clotilde"],
 | |
|       ["nom" => "enpion", "prenom" => "tarte", "annees" => "36", "ville" => "missile fixe"],
 | |
|     ];
 | |
| 
 | |
|     ###########################################################################
 | |
|     ## mappings au format chaine
 | |
| 
 | |
|     # tester includes + excludes + remap
 | |
|     # ordre du mapping
 | |
|     $w = new StringWriter();
 | |
|     $writer = new CsvWriter($w, [
 | |
|       "header_mappings" => "=prenom,annees=age,nom",
 | |
|     ]);
 | |
|     $writer->writeAll($rows);
 | |
|     self::assertSame("prenom,age,nom
 | |
| ,45,clain
 | |
| ,36,enpion
 | |
| ", $w->getString());
 | |
| 
 | |
|     # tester excludes + remap
 | |
|     # ordre de la source
 | |
|     $w = new StringWriter();
 | |
|     $writer = new CsvWriter($w, [
 | |
|       "header_mappings" => "=prenom,annees=age",
 | |
|     ]);
 | |
|     $writer->writeAll($rows);
 | |
|     self::assertSame("nom,prenom,age,ville
 | |
| clain,,45,sainte-clotilde
 | |
| enpion,,36,\"missile fixe\"
 | |
| ", $w->getString());
 | |
| 
 | |
|     ###########################################################################
 | |
|     ## mappings au format tableau
 | |
| 
 | |
|     # tester includes + excludes + remap
 | |
|     # ordre du mapping
 | |
|     $w = new StringWriter();
 | |
|     $writer = new CsvWriter($w, [
 | |
|       "header_mappings" => ["prenom" => null, "annees" => "age", "nom"],
 | |
|     ]);
 | |
|     $writer->writeAll($rows);
 | |
|     self::assertSame("prenom,age,nom
 | |
| ,45,clain
 | |
| ,36,enpion
 | |
| ", $w->getString());
 | |
| 
 | |
|     # tester excludes + remap
 | |
|     # ordre de la source
 | |
|     $w = new StringWriter();
 | |
|     $writer = new CsvWriter($w, [
 | |
|       "header_mappings" => ["prenom" => null, "annees" => "age"],
 | |
|     ]);
 | |
|     $writer->writeAll($rows);
 | |
|     self::assertSame("nom,prenom,age,ville
 | |
| clain,,45,sainte-clotilde
 | |
| enpion,,36,\"missile fixe\"
 | |
| ", $w->getString());
 | |
|   }
 | |
| }
 |