summaryrefslogtreecommitdiffstats
path: root/phoronix-test-suite
blob: 3102d5c3af80cdc1e28a8bf63265b654f1db2267 (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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
#!/bin/sh

#
#	Phoronix Test Suite
#	URLs: http://www.phoronix.com, http://www.phoronix-test-suite.com/
#	Copyright (C) 2008, Phoronix Media
#	Copyright (C) 2008, Michael Larabel
#	phoronix-test-suite: The Phoronix Test Suite is an extensible open-source testing platform for Linux.
#
#	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 3 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, see <http://www.gnu.org/licenses/>.
#

# Full path to root directory of the actual Phoronix Test Suite code
export PTS_DIR=`pwd`
CALL_DIR=`pwd`
OPTION_HANDLE=$1
OPTION_ARG=$2

if [ $PTS_DIR != `pwd` ]
then
	cd $PTS_DIR
fi

# Ensure the user is in the correct directory
if [ ! -f pts-core/pts-run-cmd.php ] || [ ! -f pts-core/pts-run-test.php ]
then
	cat <<'EOT'

To run the Phoronix Test Suite locally you must first change directories to phoronix-test-suite/ or install the program using the install-sh script. For support visit: http://www.phoronix-test-suite.com/

EOT
exit
fi

# Determine PHP binary location
if [ -x /usr/bin/php5 ] || [ -x /usr/local/bin/php5 ]
then
	export PHP_BIN="php5"
elif [ -x /usr/bin/php ] || [ -x /usr/local/bin/php ]
then
	export PHP_BIN="php"
elif [ -x /usr/php5/bin/php ]
then
	export PHP_BIN="/usr/php5/bin/php"
elif [ -x /usr/php/bin/php ]
then
	export PHP_BIN="/usr/php/bin/php"
else
	export PHP_BIN=""
fi

# Make sure PHP is installed
if [ "X$PHP_BIN" = "X" ]
then
	cat <<'EOT'

PHP5 CLI Must Be Installed To Run The Phoronix Test Suite.
Only PHP For The Command Line Is Needed, Not A Complete PHP w/ Web Server Installation
The PHP CLI package is usually called php-cli or php5-cli. Also required is the PHP GD library (php-gd)
For support visit: http://www.phoronix-test-suite.com/

EOT
exit
fi

# Check if being called from a Self Contained test profile
export SCTP_FILE=`echo $CALL_DIR/$1 | sed 's:\./::g'`
if [ -e $SCTP_FILE ]
then
	OPTION_HANDLE="benchmark"
	OPTION_ARG=$SCTP_FILE
fi

export PTS_COMMAND=$1
case "$1" in
"install" | "force-install")
	$PHP_BIN pts-core/pts-run-cmd.php INSTALL_TEST $OPTION_ARG
	;;
"install-dependencies")
	$PHP_BIN pts-core/pts-run-cmd.php INSTALL_EXTERNAL_DEPENDENCIES $OPTION_ARG
	;;
"install-all" | "force-install-all")
	$PHP_BIN pts-core/pts-run-cmd.php INSTALL_ALL
	;;
"run")
	$PHP_BIN pts-core/pts-run-test.php $OPTION_ARG
	;;
"batch-run")
	export PTS_BATCH_MODE=1
	$PHP_BIN pts-core/pts-run-test.php $OPTION_ARG
	;;
"benchmark")
	export SILENT_INSTALL=1
	$PHP_BIN pts-core/pts-run-cmd.php INSTALL_TEST $OPTION_ARG
	$PHP_BIN pts-core/pts-run-test.php $OPTION_ARG
	;;
"batch-benchmark")
	export PTS_BATCH_MODE=1
	export SILENT_INSTALL=1
	$PHP_BIN pts-core/pts-run-cmd.php INSTALL_TEST $OPTION_ARG
	$PHP_BIN pts-core/pts-run-test.php $OPTION_ARG
	;;
"merge-results")
	$PHP_BIN pts-core/pts-run-cmd.php MERGE_RESULTS $OPTION_ARG $3 $4
	;;
"analyze" | "analyze-results")
	$PHP_BIN pts-core/pts-run-cmd.php ANALYZE_RESULTS $OPTION_ARG $3
	;;
"remove-result")
	$PHP_BIN pts-core/pts-run-cmd.php REMOVE_RESULT $OPTION_ARG
	;;
"remove-installed-test")
	$PHP_BIN pts-core/pts-run-cmd.php REMOVE_INSTALLED_TEST $OPTION_ARG
	;;
"remove-all-results")
	$PHP_BIN pts-core/pts-run-cmd.php REMOVE_ALL_RESULTS
	;;
"upload" | "upload-result" | "upload-results" | "upload-saved-result")
	$PHP_BIN pts-core/pts-run-cmd.php UPLOAD_RESULT $OPTION_ARG
	;;
"make-download-cache")
	$PHP_BIN pts-core/pts-run-cmd.php MAKE_DOWNLOAD_CACHE
	;;
"list-tests" | "list-all-tests")
	$PHP_BIN pts-core/pts-run-cmd.php LIST_TESTS
	;;
"list-suites")
	$PHP_BIN pts-core/pts-run-cmd.php LIST_SUITES
	;;
"list-modules")
	$PHP_BIN pts-core/pts-run-cmd.php LIST_MODULES
	;;
"list-possible-dependencies")
	$PHP_BIN pts-core/pts-run-cmd.php LIST_POSSIBLE_EXTERNAL_DEPENDENCIES
	;;
"list-installed-tests")
	$PHP_BIN pts-core/pts-run-cmd.php LIST_INSTALLED_TESTS
	;;
"list-usage" | "list-test-usage")
	$PHP_BIN pts-core/pts-run-cmd.php LIST_TEST_USAGE
	;;
"list-results" | "list-saved-results" | "list-test-results")
	$PHP_BIN pts-core/pts-run-cmd.php LIST_SAVED_RESULTS
	;;
"result-info" | "results-info")
	$PHP_BIN pts-core/pts-run-cmd.php RESULT_INFO $OPTION_ARG
	;;
"show-result" | "show-results" | "view-result" | "view-results")
	$PHP_BIN pts-core/pts-run-cmd.php SHOW_RESULT $OPTION_ARG
	;;
"info" | "suite-info" | "suite-information" | "test-info" | "test-information")
	$PHP_BIN pts-core/pts-run-cmd.php INFO $OPTION_ARG
	;;
"module-info")
	$PHP_BIN pts-core/pts-run-cmd.php MODULE_INFO $OPTION_ARG
	;;
"module-setup")
	$PHP_BIN pts-core/pts-run-cmd.php MODULE_SETUP $OPTION_ARG
	;;
"system-info" | "system-information")
	$PHP_BIN pts-core/pts-run-cmd.php SYS_INFO
	;;
"diagnostics")
	$PHP_BIN pts-core/pts-run-cmd.php DIAGNOSTICS_DUMP
	;;
"clone")
	$PHP_BIN pts-core/pts-run-cmd.php CLONE $OPTION_ARG
	;;
"initial-config")
	$PHP_BIN pts-core/pts-run-cmd.php INITIAL_CONFIG
	;;
"version")
	$PHP_BIN pts-core/pts-run-cmd.php VERSION
	;;
"login")
	$PHP_BIN pts-core/pts-run-cmd.php LOGIN
	;;
"batch-setup")
	$PHP_BIN pts-core/pts-run-cmd.php BATCH_SETUP
	;;
"refresh-graph" | "refresh-graphs" | "refresh-result")
	$PHP_BIN pts-core/pts-run-cmd.php REFRESH_GRAPHS $OPTION_ARG
	;;
"test-module" | "debug-module")
	if [ "$1" = "debug-module" ]
	then
		export PTS_DEBUG=1
	fi

	export PTS_IGNORE_MODULES=1
	$PHP_BIN pts-core/pts-run-cmd.php TEST_MODULE $OPTION_ARG
	;;
"sensors" | "sensor-options")
	echo "\nThis option was dropped from the Phoronix Test Suite. For more information and the replacement option, view the latest documentation.\n"
	;;
*)
	cat <<'EOT'

=================================
Phoronix Test Suite
URL: http://www.phoronix-test-suite.com/
=================================

Installation Options:
	install <suite / test>: Install or update the specified suite/test(s)
	install-dependencies <suite / test>: Install the external (distribution-level) dependencies
	install-all: Install or update all available tests
	list-installed-tests: List all tests that are installed

Testing Options:
	benchmark <suite / test / saved file / Global ID>: Install and then run the test(s)
	run <suite / test / saved file / Global ID>: Run the specified test(s)
	list-tests: List all tests and relevant information
	list-suites: List all suites and relevant information

Batch Testing Options:
	batch-setup: Setup the batch mode options
	batch-run <suite OR test>: Run the specified test(s) in batch mode
	batch-benchmark <suite OR test OR saved file>: Install and run the test(s) in batch mode
	analyze <suite / test / saved file / Global ID>: Provide an analysis of the results generated from a batch run

Result Viewing Options:
	list-results: List all saved results
	show-result <saved name>: Show this result file in your web browser
	remove-result <saved name>: Remove this saved result file
	remove-all-results: Removes all saved results
	merge-results <saved Name 1 / Global ID> <saved Name 2 / Global ID> <save name>: Merge two sets of results
	upload-results <saved name>: Upload a saved set of results to Phoronix Global
	login: Enter your Phoronix Global log-in information for uploading results

Module Options:
	list-modules: List all installed/available PTS modules
	module-info: Show detailed information on a PTS module
	module-setup: Configure the end-user options for a PTS module

Miscellaneous Options:
	make-download-cache: Backup all downloaded test files to ~/.phoronix-test-suite/download-cache/
	info <suite / test>: Show detailed information about a test or suite
	system-info: Show detected software and hardware information
	diagnostics: Useful information when reporting a bug or problem
	version: Print the Phoronix Test Suite version and code-name
EOT
	;;
esac