xref: /PHP-7.0/ext/interbase/tests/003.phpt (revision 899c24a8)
1--TEST--
2InterBase: misc sql types (may take a while)
3--SKIPIF--
4<?php include("skipif.inc"); ?>
5--FILE--
6<?php
7
8    require("interbase.inc");
9    ibase_connect($test_base);
10
11    ibase_query(
12    	"create table test3 (
13            iter		integer not null,
14            v_char		char(1000),
15            v_date      timestamp,
16   	 		v_decimal4_2  		decimal(4,2),
17   	 		v_decimal4_0  		decimal(4,0),
18   	 		v_decimal7_2  		decimal(7,2),
19   	 		v_decimal7_0  		decimal(7,0),
20   	 		v_numeric15_15  	numeric(15,15),
21   	 		v_numeric15_0  	numeric(15,0),
22            v_double  	double precision,
23            v_float     float,
24            v_integer   integer,
25            v_smallint  smallint,
26            v_varchar   varchar(10000)
27            )");
28    ibase_commit();
29
30	/* should fail, but gracefully */
31	@ibase_query("insert into test3 (iter) values (?)", null);
32
33    /* if timefmt is not supported, suppress error here */
34    ini_set('ibase.timestampformat',"%m/%d/%Y %H:%M:%S");
35
36    for($iter = 0; $iter < 10; $iter++){
37    	/* prepare data  */
38    	$v_char = rand_str(1000);
39    	$v_date = rand_datetime();
40    	$v_decimal4_2 = rand_number(4,2);
41    	$v_decimal4_0 = rand_number(4,0);
42    	$v_decimal7_2 = rand_number(7,2);
43    	$v_decimal7_0 = rand_number(7,0);
44    	$v_numeric15_15 = rand_number(15,15);
45    	$v_numeric15_0 = $iter ? rand_number(15,0) : 0;
46    	$v_double  = rand_number(18);
47    	$v_float   = rand_number(7);
48    	$v_integer = rand_number(9,0);
49    	$v_smallint = rand_number(5) % 32767;
50    	$v_varchar = rand_str(10000);
51
52    	ibase_query(
53    	"insert into test3 (iter, v_char,v_date,v_decimal4_2, v_decimal4_0, v_decimal7_2, v_decimal7_0,v_numeric15_15, v_numeric15_0,v_double,v_float,v_integer,v_smallint,v_varchar)
54    	values ($iter, '$v_char','$v_date',$v_decimal4_2, $v_decimal4_0, $v_decimal7_2, $v_decimal7_0,$v_numeric15_15, $v_numeric15_0,$v_double,$v_float,$v_integer,$v_smallint,'$v_varchar')");
55    	$sel = ibase_query("select * from test3 where iter = $iter");
56    	$row = ibase_fetch_object($sel);
57    	if(substr($row->V_CHAR,0,strlen($v_char)) != $v_char){
58        	echo " CHAR fail:\n";
59            echo " in:  $v_char\n";
60            echo " out: $row->V_CHAR\n";
61        }
62        if($row->V_DATE != $v_date){
63            echo " DATE fail\n";
64            echo " in:  $v_date\n";
65            echo " out: $row->V_DATE\n";
66        }
67        if($row->V_DECIMAL4_2 != $v_decimal4_2){
68            echo " DECIMAL4_2 fail\n";
69            echo " in:  $v_decimal4_2\n";
70            echo " out: $row->V_DECIMAL4_2\n";
71        }
72        if($row->V_DECIMAL4_0 != $v_decimal4_0){
73            echo " DECIMAL4_0 fail\n";
74            echo " in:  $v_decimal4_0\n";
75            echo " out: $row->V_DECIMAL4_0\n";
76        }
77        if($row->V_DECIMAL7_2 != $v_decimal7_2){
78            echo " DECIMAL7_2 fail\n";
79            echo " in:  $v_decimal7_2\n";
80            echo " out: $row->V_DECIMAL7_2\n";
81        }
82        if($row->V_DECIMAL7_0 != $v_decimal7_0){
83            echo " DECIMAL7_0 fail\n";
84            echo " in:  $v_decimal7_0\n";
85            echo " out: $row->V_DECIMAL7_0\n";
86        }
87        if($row->V_NUMERIC15_15 != $v_numeric15_15){
88            echo " NUMERIC15_15 fail\n";
89            echo " in:  $v_numeric15_15\n";
90            echo " out: $row->V_NUMERIC15_15\n";
91        }
92        if($row->V_NUMERIC15_0 != (string)$v_numeric15_0){
93            echo " NUMERIC15_0 fail\n";
94            echo " in:  $v_numeric15_0\n";
95            echo " out: $row->V_NUMERIC15_0\n";
96        }
97
98        if(abs($row->V_DOUBLE - $v_double) > abs($v_double / 1E15)){
99            echo " DOUBLE fail\n";
100            echo " in:  $v_double\n";
101            echo " out: $row->V_DOUBLE\n";
102        }
103        if(abs($row->V_FLOAT - $v_float) > abs($v_float / 1E7)){
104            echo " FLOAT fail\n";
105            echo " in:  $v_float\n";
106            echo " out: $row->V_FLOAT\n";
107        }
108        if($row->V_INTEGER != $v_integer){
109            echo " INTEGER fail\n";
110            echo " in:  $v_integer\n";
111            echo " out: $row->V_INTEGER\n";
112        }
113        if($row->V_SMALLINT != $v_smallint){
114            echo " SMALLINT fail\n";
115            echo " in:  $v_smallint\n";
116            echo " out: $row->V_SMALLINT\n";
117        }
118
119	  if(substr($row->V_VARCHAR,0,strlen($v_varchar)) != $v_varchar){
120        	echo " VARCHAR fail:\n";
121            echo " in:  $v_varchar\n";
122            echo " out: $row->V_VARCHAR\n";
123        }
124
125        ibase_free_result($sel);
126    } /* for($iter) */
127
128	/* check for correct handling of duplicate field names */
129	$q = ibase_query('SELECT 1 AS id, 2 AS id, 3 AS id, 4 AS id, 5 AS id, 6 AS id, 7 AS id, 8 AS id, 9 AS id,
130		10 AS id, 11 AS id, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22 FROM rdb$database');
131	var_dump(ibase_fetch_assoc($q));
132
133    ibase_close();
134    echo "end of test\n";
135?>
136--EXPECT--
137array(22) {
138  ["ID"]=>
139  int(1)
140  ["ID_01"]=>
141  int(2)
142  ["ID_02"]=>
143  int(3)
144  ["ID_03"]=>
145  int(4)
146  ["ID_04"]=>
147  int(5)
148  ["ID_05"]=>
149  int(6)
150  ["ID_06"]=>
151  int(7)
152  ["ID_07"]=>
153  int(8)
154  ["ID_08"]=>
155  int(9)
156  ["ID_09"]=>
157  int(10)
158  ["ID_10"]=>
159  int(11)
160  ["CONSTANT"]=>
161  int(12)
162  ["CONSTANT_01"]=>
163  int(13)
164  ["CONSTANT_02"]=>
165  int(14)
166  ["CONSTANT_03"]=>
167  int(15)
168  ["CONSTANT_04"]=>
169  int(16)
170  ["CONSTANT_05"]=>
171  int(17)
172  ["CONSTANT_06"]=>
173  int(18)
174  ["CONSTANT_07"]=>
175  int(19)
176  ["CONSTANT_08"]=>
177  int(20)
178  ["CONSTANT_09"]=>
179  int(21)
180  ["CONSTANT_10"]=>
181  int(22)
182}
183end of test
184