2015-12-11 05:08:32 +01:00
#!/usr/bin/env php
2005-08-13 23:45:08 +02:00
< ? php
2007-08-26 14:10:50 +02:00
/* Copyright ( C ) 2003 Rodolphe Quiedeville < rodolphe @ quiedeville . org >
* Copyright ( C ) 2004 - 2007 Laurent Destailleur < eldy @ users . sourceforge . net >
2005-08-13 23:45:08 +02:00
*
* 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
2013-01-16 15:36:08 +01:00
* the Free Software Foundation ; either version 3 of the License , or
2005-08-13 23:45:08 +02:00
* ( 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
2011-08-01 00:21:57 +02:00
* along with this program . If not , see < http :// www . gnu . org / licenses />.
2005-08-13 23:45:08 +02:00
*
2007-08-26 14:10:50 +02:00
* ATTENTION DE PAS EXECUTER CE SCRIPT SUR UNE INSTALLATION DE PRODUCTION
2005-08-13 23:45:08 +02:00
*/
/**
2015-11-09 16:48:30 +01:00
* \file dev / initdata / generate - order . php
* \brief Script example to inject random orders ( for load tests )
2011-08-27 16:24:16 +02:00
*/
2005-08-13 23:45:08 +02:00
2007-08-26 14:10:50 +02:00
// Test si mode batch
$sapi_type = php_sapi_name ();
if ( substr ( $sapi_type , 0 , 3 ) == 'cgi' ) {
echo " Erreur: Vous utilisez l'interpreteur PHP pour le mode CGI. Pour executer mailing-send.php en ligne de commande, vous devez utiliser l'interpreteur PHP pour le mode CLI. \n " ;
exit ;
}
// Recupere root dolibarr
2016-07-15 19:44:45 +02:00
//$path=preg_replace('/generate-commande.php/i','',$_SERVER["PHP_SELF"]);
require ( __DIR__ . '/../../htdocs/master.inc.php' );
2012-08-23 02:04:35 +02:00
include_once DOL_DOCUMENT_ROOT . '/societe/class/societe.class.php' ;
include_once DOL_DOCUMENT_ROOT . '/contact/class/contact.class.php' ;
include_once DOL_DOCUMENT_ROOT . '/compta/facture/class/facture.class.php' ;
include_once DOL_DOCUMENT_ROOT . '/product/class/product.class.php' ;
include_once DOL_DOCUMENT_ROOT . '/compta/paiement/class/paiement.class.php' ;
include_once DOL_DOCUMENT_ROOT . '/contrat/class/contrat.class.php' ;
2017-02-16 01:40:01 +01:00
require_once ( DOL_DOCUMENT_ROOT . " /commande/class/commande.class.php " );
2005-08-13 23:45:08 +02:00
/*
* Parametre
*/
2012-02-15 13:58:37 +01:00
define ( GEN_NUMBER_COMMANDE , 10 );
2017-02-16 01:40:01 +01:00
$year = 2016 ;
$dates = array ( mktime ( 12 , 0 , 0 , 1 , 3 , $year ),
mktime ( 12 , 0 , 0 , 1 , 9 , $year ),
mktime ( 12 , 0 , 0 , 2 , 13 , $year ),
mktime ( 12 , 0 , 0 , 2 , 23 , $year ),
mktime ( 12 , 0 , 0 , 3 , 30 , $year ),
mktime ( 12 , 0 , 0 , 4 , 3 , $year ),
mktime ( 12 , 0 , 0 , 4 , 3 , $year ),
mktime ( 12 , 0 , 0 , 5 , 9 , $year ),
mktime ( 12 , 0 , 0 , 5 , 1 , $year ),
mktime ( 12 , 0 , 0 , 5 , 13 , $year ),
mktime ( 12 , 0 , 0 , 5 , 19 , $year ),
mktime ( 12 , 0 , 0 , 5 , 23 , $year ),
mktime ( 12 , 0 , 0 , 6 , 3 , $year ),
mktime ( 12 , 0 , 0 , 6 , 19 , $year ),
mktime ( 12 , 0 , 0 , 6 , 24 , $year ),
mktime ( 12 , 0 , 0 , 7 , 3 , $year ),
mktime ( 12 , 0 , 0 , 7 , 9 , $year ),
mktime ( 12 , 0 , 0 , 7 , 23 , $year ),
mktime ( 12 , 0 , 0 , 7 , 30 , $year ),
mktime ( 12 , 0 , 0 , 8 , 9 , $year ),
mktime ( 12 , 0 , 0 , 9 , 23 , $year ),
mktime ( 12 , 0 , 0 , 10 , 3 , $year ),
mktime ( 12 , 0 , 0 , 11 , 12 , $year ),
mktime ( 12 , 0 , 0 , 11 , 13 , $year ),
mktime ( 12 , 0 , 0 , 1 , 3 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 1 , 9 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 2 , 13 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 2 , 23 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 3 , 30 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 4 , 3 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 4 , 3 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 5 , 9 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 5 , 1 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 5 , 13 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 5 , 19 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 5 , 23 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 6 , 3 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 6 , 19 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 6 , 24 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 7 , 3 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 7 , 9 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 7 , 23 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 7 , 30 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 8 , 9 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 9 , 23 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 10 , 3 ,( $year - 1 )),
mktime ( 12 , 0 , 0 , 11 , 12 , $year ),
mktime ( 12 , 0 , 0 , 11 , 13 , $year ),
mktime ( 12 , 0 , 0 , 12 , 12 , $year ),
mktime ( 12 , 0 , 0 , 12 , 13 , $year ),
);
2005-08-13 23:45:08 +02:00
2010-10-20 20:55:12 +02:00
$ret = $user -> fetch ( '' , 'admin' );
if ( $ret <= 0 )
{
print 'A user with login "admin" and all permissions must be created to use this script.' . " \n " ;
exit ;
}
$user -> getrights ();
2017-02-16 01:40:01 +01:00
$societesid = array ();
$sql = " SELECT rowid FROM " . MAIN_DB_PREFIX . " societe where client in (1, 3) " ;
2007-08-26 14:10:50 +02:00
$resql = $db -> query ( $sql );
if ( $resql ) {
2017-02-16 01:40:01 +01:00
$num_thirdparties = $db -> num_rows ( $resql );
2007-08-26 14:10:50 +02:00
$i = 0 ;
2017-02-16 01:40:01 +01:00
while ( $i < $num_thirdparties ) {
2007-08-26 14:10:50 +02:00
$i ++ ;
2017-02-16 01:40:01 +01:00
$row = $db -> fetch_row ( $resql );
$societesid [ $i ] = $row [ 0 ];
2006-09-09 15:05:45 +02:00
}
}
else { print " err " ; }
2005-08-13 23:45:08 +02:00
2017-02-16 01:40:01 +01:00
$commandesid = array ();
$sql = " SELECT rowid FROM " . MAIN_DB_PREFIX . " commande " ;
2007-08-26 14:10:50 +02:00
$resql = $db -> query ( $sql );
if ( $resql ) {
$num = $db -> num_rows ( $resql );
$i = 0 ;
2006-09-09 15:05:45 +02:00
while ( $i < $num ) {
2007-08-26 14:10:50 +02:00
$i ++ ;
2017-02-16 01:40:01 +01:00
$row = $db -> fetch_row ( $resql );
$commandesid [ $i ] = $row [ 0 ];
2006-09-09 15:05:45 +02:00
}
}
else { print " err " ; }
$prodids = array ();
2010-08-11 20:35:31 +02:00
$sql = " SELECT rowid FROM " . MAIN_DB_PREFIX . " product WHERE tosell=1 " ;
2006-09-09 15:05:45 +02:00
$resql = $db -> query ( $sql );
2010-10-20 20:55:12 +02:00
if ( $resql )
2006-09-09 15:05:45 +02:00
{
$num_prods = $db -> num_rows ( $resql );
$i = 0 ;
while ( $i < $num_prods )
{
$i ++ ;
2010-10-20 20:55:12 +02:00
2006-09-09 15:05:45 +02:00
$row = $db -> fetch_row ( $resql );
$prodids [ $i ] = $row [ 0 ];
}
}
2005-08-13 23:45:08 +02:00
2007-08-26 14:10:50 +02:00
print " Build " . GEN_NUMBER_COMMANDE . " orders \n " ;
2005-08-13 23:45:08 +02:00
for ( $s = 0 ; $s < GEN_NUMBER_COMMANDE ; $s ++ )
{
2010-10-20 20:55:12 +02:00
print " Process order " . $s . " \n " ;
2006-09-09 15:05:45 +02:00
2017-02-16 01:40:01 +01:00
$object = new Commande ( $db );
$object -> socid = $societesid [ mt_rand ( 1 , $num_thirdparties )];
$object -> date_commande = $dates [ mt_rand ( 1 , count ( $dates ) - 1 )];
$object -> note = 'My small comment about this order. Hum. Nothing.' ;
$object -> source = 1 ;
$object -> fk_project = 0 ;
$object -> remise_percent = 0 ;
$object -> shipping_method_id = mt_rand ( 1 , 2 );
$object -> cond_reglement_id = mt_rand ( 0 , 2 );
$object -> more_reglement_id = mt_rand ( 0 , 7 );
$object -> availability_id = mt_rand ( 0 , 1 );
$listofuserid = array ( 12 , 13 , 16 );
$fuser = new User ( $db );
$fuser -> fetch ( $listofuserid [ mt_rand ( 0 , 2 )]);
$fuser -> getRights ();
2010-10-20 20:55:12 +02:00
$db -> begin ();
2017-02-16 01:40:01 +01:00
$result = $object -> create ( $fuser );
2007-08-26 14:10:50 +02:00
if ( $result >= 0 )
{
2017-02-16 01:40:01 +01:00
$nbp = mt_rand ( 2 , 5 );
$xnbp = 0 ;
while ( $xnbp < $nbp )
{
$prodid = mt_rand ( 1 , $num_prods );
$product = new Product ( $db );
$result = $product -> fetch ( $prodids [ $prodid ]);
$result = $object -> addline ( $product -> description , $product -> price , mt_rand ( 1 , 5 ), 0 , 0 , 0 , $prodids [ $prodid ], 0 , 0 , 0 , $product -> price_base_type , $product -> price_ttc , '' , '' , $product -> type );
if ( $result <= 0 )
2010-10-20 20:55:12 +02:00
{
2017-02-16 01:40:01 +01:00
dol_print_error ( $db , $object -> error );
2010-10-20 20:55:12 +02:00
}
2017-02-16 01:40:01 +01:00
$xnbp ++ ;
}
2010-10-20 20:55:12 +02:00
2017-02-16 01:40:01 +01:00
$result = $object -> valid ( $fuser );
if ( $result > 0 )
{
2010-10-20 20:55:12 +02:00
$db -> commit ();
2017-02-16 01:40:01 +01:00
print " OK with ref " . $object -> ref . " \n " ;
2010-10-20 20:55:12 +02:00
}
2007-08-26 14:10:50 +02:00
else
{
2010-10-20 20:55:12 +02:00
print " KO \n " ;
$db -> rollback ();
2017-02-16 01:40:01 +01:00
dol_print_error ( $db , $object -> error );
2007-08-26 14:10:50 +02:00
}
}
else
{
2010-10-20 20:55:12 +02:00
print " KO \n " ;
$db -> rollback ();
2017-02-16 01:40:01 +01:00
dol_print_error ( $db , $object -> error );
2007-08-26 14:10:50 +02:00
}
2005-08-13 23:45:08 +02:00
}