summaryrefslogtreecommitdiff
path: root/ext/oci8/tests/details.inc
blob: e54ea84abdb47ef4cf3b4bdad9c6647b8d14aa76 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
<?php

/*
 * Please change $user, $password and $dbase to match your configuration.
 *
 * Set $test_drcp to TRUE if you want to run the Oracle Database
 * Resident Connection Pooling (DRCP) tests. For these tests to run
 * successfully, you need a server and client which is Oracle 11g or
 * greater, and $dbase should be set to the tnsnames.ora entry
 * corresponding to the POOLED server instance or an Easy Connect
 * string like hostname:port/service_name:POOLED
 */

if (file_exists(dirname(__FILE__)."/details_local.inc")) {
	include(dirname(__FILE__)."/details_local.inc");   // this file is not part of the source distribution; make it your own local variant of details.inc
} else {
	if (false !== getenv('PHP_OCI8_TEST_DB')) {
		$user		= getenv('PHP_OCI8_TEST_USER');	  // Database username for tests
		$password	= getenv('PHP_OCI8_TEST_PASS');	  // Password for $user
		$dbase		= getenv('PHP_OCI8_TEST_DB');	  // Database connection string
		$test_drcp	= getenv('PHP_OCI8_TEST_DRCP');
		if (false !== $test_drcp && 0 == strcasecmp($test_drcp,'TRUE')) {
			$test_drcp = TRUE;
		} else {
			$test_drcp = FALSE;
		}
	} else {
		$user						= "system";
		$password					= "oracle";
		$dbase						= "localhost/XE";
		$test_drcp					= FALSE;
	}
	
	/*
	 * Common object names for scripts to use
	 */
	
	$table_name = "tb".substr(str_replace(Array(".", "-"), "_", php_uname("n")), 0, 5);
	$type_name = strtoupper("tp".substr(str_replace(Array(".", "-"), "_", php_uname("n")), 0, 5));
	$schema = '';
}


/*
 * Used for creating/dropping schema objects used by a test
 */

if (!function_exists('oci8_test_sql_execute')) {
    function oci8_test_sql_execute($c, $stmtarray)
    {
        foreach ($stmtarray as $stmt) {
            $s = oci_parse($c, $stmt);
            if (!$s) {
                $m = oci_error($c);
                echo "oci8_test_sql_execute() error:". PHP_EOL . $stmt . PHP_EOL . $m['message'] . PHP_EOL;
            }
            else {
                $r = @oci_execute($s);
                if (!$r) {
                    $m = oci_error($s);
                    if (!in_array($m['code'], array(   // ignore expected errors
								    942 // table or view does not exist
                                ,  1918 // user does not exist
                                ,  2024 // database link not found
                                ,  2289 // sequence does not exist
                                ,  4080 // trigger does not exist
                                , 38802 // edition does not exist
                            ))) {
			echo "oci8_test_sql_execute() error:". PHP_EOL . $stmt . PHP_EOL . $m['message'] . PHP_EOL;
                    }
                }
            }
        }
    }

}

?>