noalyss-commit
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Noalyss-commit] [noalyss] 01/04: Document_Modele : add test , improve c


From: Dany De Bontridder
Subject: [Noalyss-commit] [noalyss] 01/04: Document_Modele : add test , improve code
Date: Thu, 27 Apr 2023 12:03:35 -0400 (EDT)

sparkyx pushed a commit to branch devel
in repository noalyss.

commit b787a63a910e7293cbee29897817082fe3916d7e
Author: sparkyx <danydb@noalyss.eu>
AuthorDate: Thu Apr 27 16:29:31 2023 +0200

    Document_Modele : add test , improve code
---
 include/class/document_modele.class.php         |  38 +++--
 unit-test/include/class/Document_ModeleTest.php | 192 ++++++++++++++++++++++++
 2 files changed, 218 insertions(+), 12 deletions(-)

diff --git a/include/class/document_modele.class.php 
b/include/class/document_modele.class.php
index 571e3a499..19ae172e0 100644
--- a/include/class/document_modele.class.php
+++ b/include/class/document_modele.class.php
@@ -34,11 +34,13 @@ class Document_modele
     var $sequence;        /*!< $sequence sequence number used by the create 
sequence start with */
     var $md_affect;    /*!< $md_affect if you can use it in VEN for sale, ACH 
for purchase or GES for follow-up */
     var $md_filename;   /*! < $md_filename is the filename of the template */
+    var $start;   /*! < $md_filename is the filename of the template */
     //Constructor parameter = database connexion
     function __construct($p_cn,$p_id=-1)
     {
         $this->cn=$p_cn;
         $this->md_id=$p_id;
+        $this->start=0;
     }
 
     /*!
@@ -157,7 +159,7 @@ class Document_modele
             $new_name=tempnam($_ENV['TMP'],'document_');
             if ( strlen ($_FILES['doc']['tmp_name']) != 0 )
             {
-                if (move_uploaded_file($_FILES['doc']['tmp_name'],
+                if ($this->move_uploaded_file($_FILES['doc']['tmp_name'],
                                        $new_name))
                 {
                     // echo "Image saved";
@@ -174,7 +176,7 @@ class Document_modele
                     {
                         $r=Database::fetch_array($ret,0);
                         $old_oid=$r['md_lob'];
-                        if (strlen($old_oid) != 0)
+                        if (strlen(""??$old_oid) != 0)
                             $this->cn->lo_unlink($old_oid);
                     }
                     // Load new document
@@ -196,6 +198,10 @@ class Document_modele
             return ;
         }
     }
+    function move_uploaded_file($temporary_name, $target_path)
+    {
+        return move_uploaded_file ($temporary_name, $target_path);
+    }
     /*!
      * \brief Remove a template
      * \return nothing
@@ -204,19 +210,18 @@ class Document_modele
     {
         $this->cn->start();
         // first we unlink the document
-        $sql="select md_lob from document_modele where md_id=".$this->md_id;
-        $res=$this->cn->exec_sql($sql);
+        $sql="select md_lob from document_modele where md_id=$1";
+        $res=$this->cn->exec_sql($sql,[$this->md_id]);
         $r=Database::fetch_array($res,0);
         // if a lob is found
-        if ( strlen ($r['md_lob']) &&
-                $this->cn->exist_blob($r['md_lob']) )
+        if ( !empty ($r['md_lob']) &&$this->cn->exist_blob($r['md_lob']) )
         {
             // we remove it first
             $this->cn->lo_unlink($r['md_lob']);
         }
         // now we can delete the row
-        $sql="delete from document_modele where md_id =".$this->md_id;
-        $sql=$this->cn->exec_sql($sql);
+        $sql="delete from document_modele where md_id =$1";
+        $res=$this->cn->exec_sql($sql,[$this->md_id]);
         $this->cn->commit();
     }
 
@@ -323,7 +328,7 @@ class Document_modele
             $new_name=tempnam($_ENV['TMP'],'document_');
             if ( strlen ($_FILES['doc']['tmp_name']) != 0 )
             {
-                if (move_uploaded_file($_FILES['doc']['tmp_name'],
+                if ($this->move_uploaded_file($_FILES['doc']['tmp_name'],
                                        $new_name))
                 {
                     // echo "Image saved";
@@ -344,7 +349,16 @@ class Document_modele
                             $this->cn->lo_unlink($old_oid);
                     }
                     // Load new document
-                    $this->cn->exec_sql("update document_modele set 
md_lob=".$oid.", md_mimetype='".$_FILES['doc']['type']."' 
,md_filename='".$_FILES['doc']['name']."' where md_id=".$this->md_id);
+
+                    $this->cn->exec_sql("update document_modele 
+                        set md_lob=$1, 
+                            md_mimetype=$2,
+                            md_filename=$3
+                        where md_id=$4",[
+                            $oid,
+                            $_FILES['doc']['type'],
+                            $_FILES['doc']['name'],
+                            $this->md_id]);
                     $this->cn->commit();
                 }
                 else
@@ -357,8 +371,8 @@ class Document_modele
         }
         catch (Exception $e)
         {
-              record_log($e);
-            rollback($this->cn);
+            record_log($e);
+            $this->cn->rollback();
             return ;
         }
        $this->cn->commit();
diff --git a/unit-test/include/class/Document_ModeleTest.php 
b/unit-test/include/class/Document_ModeleTest.php
new file mode 100644
index 000000000..314f12e57
--- /dev/null
+++ b/unit-test/include/class/Document_ModeleTest.php
@@ -0,0 +1,192 @@
+<?php
+
+/*
+ * * Copyright (C) 2022 Dany De Bontridder <dany@alchimerys.be>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+ *
+ * 
+ * Author : Dany De Bontridder danydb@noalyss.eu
+ * 27/04/23
+ */
+
+/**
+ * @file
+ * @brief noalyss
+ */
+namespace NOALYSS\Test;
+use PHPUnit\Framework\TestCase;
+
+require DIRTEST . '/global.php';
+
+class Document_Modele extends  \Document_modele
+{
+    function move_uploaded_file($temporary_name, $target_path)
+    {
+         return copy ($temporary_name, $target_path);
+    }
+
+}
+
+/**
+ * @backupGlobals enabled
+ * @coversDefaultClass
+ */
+class Document_ModeleTest extends TestCase
+{
+
+    /**
+     * @var Fiche
+     */
+    protected $object_id;
+    protected $type_id;
+
+    /**
+     * Sets up the fixture, for example, opens a network connection.
+     * This method is called before a test method is executed.
+     */
+    protected function setUp(): void
+    {
+        $g_connection=\Dossier::connect();
+
+        $g_connection->exec_sql("delete from document_modele where 
md_affect='TST'");
+        $g_connection->exec_sql("delete from document_type where 
dt_value='PHPUNIT'");
+
+        $this->type_id=$g_connection->get_value("insert into document_type 
(dt_value,dt_prefix) values ('PHPUNIT','TST')returning  dt_id");
+
+        $md_id=$g_connection->get_next_seq('document_modele_md_id_seq');
+        $sql="insert into document_modele(md_id,md_name,md_type,md_affect)
+                     values ($1,$2,$3,$4)";
+        $g_connection->exec_sql($sql,[$md_id,'UNIT 
TEST',$this->type_id,'TST']);
+        $this->object_id=$md_id;
+
+    }
+
+    /**
+     * Tears down the fixture, for example, closes a network connection.
+     * This method is called after a test method is executed.
+     */
+    protected function tearDown(): void
+    {
+
+        $g_connection=\Dossier::connect();
+
+        $g_connection->exec_sql("delete from document_modele where 
md_affect='TST'");
+        $g_connection->exec_sql("delete from document_type where 
dt_value='PHPUNIT'");
+    }
+
+    /**
+     * the setUpBeforeClass() template methods is called before the first test 
of the test case
+     *  class is run
+     */
+    public static function setUpBeforeClass(): void
+    {
+        //        include 'global.php';
+    }
+
+    /**
+     *  tearDownAfterClass() template methods is calleafter the last test of 
the test case class is run,
+     *
+     */
+    static function tearDownAfterClass(): void
+    {
+        //        include 'global.php';
+    }
+//
+//    public function dataExample()
+//    {
+//        return array([1], [2], [3]);
+//    }
+
+    /**
+     *
+     * @return void
+     */
+    function testSaveDeleteUpate()
+    {
+        $g_connection=\Dossier::connect();
+        $document_modele=new Document_modele($g_connection);
+        $document_modele->md_name="SAVETESTPHPUNIT";
+        $document_modele->md_type=$this->type_id;
+        $document_modele->md_affect="TST";
+        // make file
+        $_FILES=array();
+        $_FILES['doc']=[];
+        $_FILES['doc']['name']="test-lob.bin";
+        $_FILES['doc']['error']=0;
+        $this->assertFileExists(__DIR__."/data/".$_FILES['doc']['name'],
+            $_FILES['doc']['name']." file absent , pls create it");
+
+        
$_FILES['doc']['size']=stat(__DIR__."/data/".$_FILES['doc']['name'])['size'];
+        $_FILES['doc']['tmp_name']=tempnam("/tmp","rsult");
+
+
+
+        //  dd if=/dev/zero of=test-lob.bin bs=4096 count=1
+        $_FILES['doc']['type']="app/bin";
+        // save file
+        $document_modele->save();
+
+
+
+        $this->assertTrue($g_connection->get_value("select count(*) from 
document_modele where md_id=$1 ",[$document_modele->md_id])>0,'Document Modele 
not created');
+
+        // is the file really loaded ?
+        $lob_save=$g_connection->get_value("select md_lob from document_modele 
where md_id=$1 ",[$document_modele->md_id]);
+
+        $this->assertTrue(! empty($lob_save),"Document no loaded");
+
+        //unset ($_FILES);
+
+        
$document_modele->update(['md_name'=>'XXXX',"md_type"=>"1","md_affect"=>'E','seq'=>0]);
+
+        $this->assertEquals( 'XXXX',$g_connection->get_value("select md_name 
from document_modele where md_id=$1",[$document_modele->md_id]) ,'update 
md_name failed');
+        $this->assertTrue($g_connection->get_value("select md_type from 
document_modele where md_id=$1",[$document_modele->md_id]) == '1','update 
md_type failed');
+
+        // is the file really loaded ?
+        $lob=$g_connection->get_value("select md_lob from document_modele 
where md_id=$1 ",[$document_modele->md_id]);
+
+        $this->assertTrue(! empty($lob),"Document no loaded");
+        $this->assertTrue($lob <> $lob_save, "LOB not updated");
+
+        // file correct ? file size = 0 kb ,PHP bug ?
+        //=========================================================
+        /*
+        $g_connection->start();
+        
$this->assertTrue($g_connection->lo_export($lob,__DIR__."/data/result.bin")," 
can not export LOB");
+        $g_connection->commit();
+
+        
$this->assertFileEquals(__DIR__."/data/".$_FILES['doc']['name'],__DIR__."/data/result.bin","file
 corrupted");
+        */
+        $document_modele->delete();
+        $this->assertTrue($g_connection->get_value("select count(*) from 
document_modele where md_id=$1 ",[$document_modele->md_id]) == 0,'Document 
Modele not deleted');
+    }
+
+    /**
+     *
+     * @return void
+     */
+    function testLoad()
+    {
+        $g_connection=\Dossier::connect();
+        $document_modele=new Document_Modele($g_connection,$this->object_id);
+        $document_modele->load();
+        //UNIT TEST',$this->type_id,'TST']
+        $this->assertEquals($document_modele->md_name,'UNIT TEST');
+        $this->assertEquals($document_modele->md_type,$this->type_id);
+        $this->assertEquals($document_modele->md_affect,'TST');
+
+    }
+}
\ No newline at end of file



reply via email to

[Prev in Thread] Current Thread [Next in Thread]