source: trunk/devel/run @ 1485

Last change on this file since 1485 was 1485, checked in by moo, 7 months ago

improve devel testing

  • Property svn:executable set to *
File size: 7.9 KB
Line 
1#!/bin/bash
2# this script is for developers only
3
4set -e
5MAKE=/usr/bin/make
6
7true() { # {{{1
8    return 0
9}
10
11hi() { # {{{1
12    colors=(4 2 3 5 6 7 8 9)
13    re=()
14    i=0
15    for r in "$@"; do
16        ((color=$i % ${#colors[@]})) || true
17        color=${colors[$color]}
18        r="${r/\#/\\#}"
19        r="s#$r#[4${color}m[31m\0[0m#g"
20        re[$i]="-e$r"
21        ((i=i+1))
22    done
23    sed -ur "${re[@]}"
24}
25hiecho() { # {{{1
26    echo "[32m""$@""[0m"
27}
28
29# }}}
30
31stopfpm() { # {{{1
32    if [[ -f $1 ]]; then
33        local pid=`cat $1 2>/dev/null || true`
34        if [[ $pid -gt 0 ]]; then
35            hiecho Stopping fpm $pid @ $1
36            kill $pid || true
37        fi
38    fi
39}
40
41xtest() { # {{{1
42    $MAKE ${MAKEOPTS} -f devel/test.mak
43}
44
45prep() { # {{{1
46    $MAKE ${MAKEOPTS} -f devel/prepare.mak "$@"
47}
48
49mergepo() { # {{{1
50    prep
51    local i
52    find htdocs -iname '*.po' | while read -r i; do
53        if [[ -f $i-merged ]]; then
54            mv $i-merged $i
55        fi
56    done
57}
58
59po2php() { # {{{1
60    mergepo
61
62    local phpfile
63    find htdocs -iname '*.po' | while read -r i; do
64        phpfile=${i/.po/.php}
65        devel/po2php.awk < $i > $phpfile.tmp
66        mv $phpfile.tmp $phpfile
67    done
68}
69
70updatedeps() { # {{{1
71    pwd=$(readlink -f "$(pwd)")
72    builddir=$(readlink -f ../trunk-php5-debug-zts)
73    if [[ -z $builddir ]]; then
74        hiecho required ../trunk-php5-debug-zts not found
75        return 1
76    fi
77    find . -iname \*.c | LANG=C sort | while read -r sourceFile; do
78        sourceFile=${sourceFile#./}
79        {
80            case "$sourceFile" in
81            includes.c)
82                echo '$(XCACHE_INCLUDES_I)'
83                ;;
84            esac
85            echo ${sourceFile%.c}.lo '$(builddir)/'${sourceFile%.c}.lo:
86            hiecho "Checking $sourceFile ..." >&2
87            for dependency in $(gcc -DHAVE_XCACHE_TEST -DHAVE_XCACHE_DPRINT -DXCACHE_DEBUG -MM $sourceFile -I$PHPSDIR/$phpbasename/include/php/{,main,Zend,TSRM} -I. -I${builddir} -MG | sed 's#.*:##g' | sed 's#\\##g'); do
88                dependency=$(readlink -f "$dependency")
89                case "$dependency" in
90                $pwd/*)
91                    dependency=${dependency#$pwd/}
92                    ;;
93                $builddir/*)
94                    dependency="\$(builddir)/"${dependency#$builddir/}
95                    ;;
96                esac
97
98                case "$dependency" in
99                *xc_const_string_opcodes_php*)
100                    for dependency in xcache/xc_const_string_*.h; do
101                        echo '$(srcdir)/'$dependency
102                    done
103                    ;;
104
105                /*) ;;
106                $sourceFile) ;;
107
108                xc_processor.h|\$\(builddir\)/xc_processor.h)
109                    echo '$(XCACHE_PROC_H)'
110                    ;;
111                xc_processor.c.h|\$\(builddir\)/xc_processor.c.h)
112                    echo '$(XCACHE_PROC_C)'
113                    ;;
114                *)
115                    if [[ -r $dependency ]]; then
116                        echo '$(srcdir)/'$dependency
117                    else
118                        hiecho "$dependency not found" >&2
119                    fi
120                esac
121            done | LANG=C sort | uniq
122        } | xargs
123    done > Makefile.frag.deps
124}
125# }}}1
126
127hiecho "Loading config devel/run.cfg"
128. devel/run.cfg
129PHPSDIR=${PHPSDIR:-$HOME/test}
130
131if [[ $# -eq 0 ]]; then
132    set -- "${args[@]}"
133fi
134
135basename=$(basename $(pwd))
136case "$basename" in
137*-*)
138    # in build dir, starts from src dir
139    dirs="${basename#*-}"
140    xcachesrcdir=../${basename%%-*}
141    cd $xcachesrcdir
142    ;;
143*)
144    # in src dir
145    dirs=${dirs:-php5-debug-zts}
146    xcachesrcdir=../$basename
147    ;;
148esac
149
150touch devel.pid
151svn propget svn:ignore . > .svnignore
152
153# ==========================
154
155do_phpize() { # {{{1
156    if [[ ! -x $PHPSDIR/$phpbasename/bin/phpize ]]; then
157        hiecho $PHPSDIR/$phpbasename/bin/phpize not found
158        exit
159    fi
160    export PATH=$PHPSDIR/$phpbasename/bin:$PATH
161    local pedantic=
162    case $phpbasename in
163    php5|php5.4) pedantic=-pedantic-errors;;
164    *) pedantic=-pedantic;;
165    esac
166    phpize --clean \
167    && phpize \
168    && CFLAGS="$CFLAGS -g -O0 $pedantic -Wno-variadic-macros -Wno-long-long -Wall -Wno-unused-parameter -Wno-unused-function -W -Wshadow -Werror=implicit-function-declaration -std=c89 -D_GNU_SOURCE -D_POSIX_SOURCE -Dinline=" ./configure \
169        --enable-xcache-cacher \
170        --enable-xcache-optimizer \
171        --enable-xcache-encoder \
172        --enable-xcache-decoder \
173        --enable-xcache-disassembler \
174        --enable-xcache-assembler \
175        --enable-xcache-coverager \
176        --enable-xcache-test \
177        --enable-xcache-dprint \
178        --enable-xcache-constant
179}
180do_make() { # {{{1
181    if [[ ! -f Makefile ]]; then
182        do_phpize
183    fi
184    LANG=C $MAKE $MAKEOPTS "$@" 2>&1 \
185    | sed -ur \
186        -e 's#Werror=implicit-function-declaration#We/rror=i/mplicit-function-declaration#' \
187        -e 's#-pedantic-errors#-pedantic-e/rrors#' \
188        -e 's#\./xc_processor\.h#'$PWD'/xc_processor.h#' \
189        -e 's#\./xc_processor\.c\.h#'$PWD'/xc_processor.c.h#' \
190    | hi error implicit warn FAIL
191    ret=${PIPESTATUS[0]}
192    if [[ $ret -ne 0 ]]; then
193        exit $ret
194    fi
195}
196cleanfpm() { # {{{1
197    echo
198    stopfpm $pidfile
199}
200# }}}
201run() {
202    pidfile=$xcachesrcdir/devel.pid
203
204    # prepare {{{1
205    case "$1" in
206    phpize)
207        if [[ -r Makefile ]]; then
208            $MAKE $MAKEOPTS xcachesvnclean || true
209        fi
210        ;;
211    esac
212
213    rm -f php-src
214    find -L . -type d -print0 | xargs -0 rmdir -p 2>/dev/null || true
215    find -L . -type l -print0 | xargs -0 rm -fv
216    lndir "$xcachesrcdir" >/dev/null || true
217    find . -iname .\*.swp -print0 | xargs -0 rm -f
218    ln -snf ~/src/php/${phpbasename%%-*} php-src
219    for i in ~/src/php/$phpbasename/sapi/cgi/php{,-cgi}; do
220        if [[ -r $i ]]; then
221            ln -snf "$i" php-cgi
222        fi
223    done
224    ln -snf ~/src/php/$phpbasename/sapi/cli/php php-cli
225    f=~/src/php/$phpbasename/sapi/cli/php; [ -f "$f" ] && ln -snf "$f" php-cli
226    f=~/src/php/$phpbasename/sapi/fpm/php-fpm; [ -f "$f" ] && ln -snf "$f" php-fpm
227
228    case "$1" in
229    phpize) do_phpize; return $?;;
230    make) shift; do_make "$@"; return $?;;
231    *) do_make;;
232    esac
233    # }}}1
234
235    if [[ -z $1 ]]; then
236        set -- devel/sample.cpp.php
237    fi
238
239    cmd=()
240    phpApp=()
241    tracer=()
242
243    # run utils {{{1
244    case "$1" in
245    retest)
246        shift
247        lastResult=$(ls php_test_results_*.txt | LANG=C sort | tail -n1)
248        $MAKE $MAKEOPTS xcachetest "$@" TESTS="$(grep '^/.*\.phpt$' $lastResult | uniq | xargs)"
249        return
250        ;;
251    test)
252        shift
253        case "$1" in
254        *.phpt)
255            $MAKE $MAKEOPTS xcachetest TEST_ARGS=-v TESTS="$*"
256            return
257            ;;
258        */)
259            $MAKE $MAKEOPTS xcachetest TESTS="$*"
260            return
261            ;;
262        *)
263            $MAKE $MAKEOPTS xcachetest
264            return
265            ;;
266        esac
267        ;;
268    esac
269    # }}}
270    # pick tracer {{{1
271    case "$1" in
272    ltr*)
273        shift
274        export USE_ZEND_ALLOC=0
275        tracer=(ltrace -s1024 -e malloc,realloc,free,write)
276        ;;
277    str*)
278        shift
279        tracer=(strace -s1024 -T)
280        ;;
281    gdb)
282        shift
283        #USE_ZEND_ALLOC=0
284        tracer=(gdb --args)
285        ;;
286    val*)
287        shift
288        export USE_ZEND_ALLOC=0
289        export ZEND_DONT_UNLOAD_MODULES=1
290        tracer=(valgrind -v --gen-suppressions=all)
291        ;;
292    esac
293
294    # pick sapi {{{1
295    case "$phpbasename" in
296    *-apache1*)
297        cmd=($HOME/apache1/bin/httpd -X)
298        ;;
299    *-apache*)
300        echo "Don't know how to run apache"
301        exit 1
302        ;;
303    *)
304        case "$1" in
305        dc)
306            shift
307            cmd=(./php-cli -c devel.ini)
308            phpApp=(./bin/phpdc.phpr)
309            ;;
310        dop)
311            shift
312            cmd=(./php-cli -c devel.ini)
313            phpApp=(./bin/phpdop.phpr)
314            ;;
315        fcgi)
316            shift
317            cmd=(./php-cgi -q -c devel.ini)
318            set -- -b 1026
319            ;;
320        fpm)
321            shift
322            cmd=(./php-fpm -c devel.ini -y devel.fpm -g $(readlink -f $pidfile))
323            set --
324            ;;
325        *)
326            cmd=(./php-cgi -q -c devel.ini)
327            ;;
328        esac
329
330        "${cmd[@]}" -v || true
331    esac
332
333    # hack sample.cpp.php {{{1
334    case "$1" in
335    *.cpp.php)
336        < "$1" \
337        sed -r -e 's#__#____#g' \
338        | cpp -C -P -traditional-cpp -DPHP_VERSION=$phpVersion \
339        | sed -r -e 's#^ +##g' -e 's#\t +#\t#g' -e 's#____#__#g' > devel.php || exit $?
340        shift
341        set -- devel.php "$@"
342        ;;
343    esac
344
345    # run {{{1
346    set -- "${tracer[@]}" "${cmd[@]}" "${phpApp[@]}" "$@"
347
348    case "${cmd[0]}" in
349    *php-fpm*)
350        stopfpm
351        hiecho Starting fpm "$@" ...
352        "$@" | tee output.php
353        echo -n "Ctrl-C to stop"
354        trap cleanfpm SIGINT SIGTERM exit
355        cat > /dev/null || true
356        stopfpm
357        return
358        ;;
359    *)
360        hiecho "$@"
361        case "${tracer[@]}" in
362        gdb*|val*)
363            "$@"
364            ;;
365        *)
366            "$@" | tee output.php
367            ;;
368        esac
369        ;;
370    esac
371    # }}}
372}
373
374for phpbasename in "${dirs[@]}"; do
375    phpVersion=${phpbasename%%-*}
376    phpVersion=${phpVersion##php}
377    phpVersion=${phpVersion/./}
378    case "$phpVersion" in
379    ??) phpVersion="${phpVersion}0";;
380    ?) phpVersion="${phpVersion}00";;
381    esac
382
383    # devel actions
384    case "$1" in
385    prep*) shift; prep "$@"; exit;;
386    tags) shift; rm -f tags; prep tags "$@"; exit;;
387    po2php) po2php; exit;;
388    mergepo) mergepo; exit;;
389    dep*) updatedeps; exit;;
390    xtest) xtest; exit;;
391    stopfpm) stopfpm devel.pid; exit;;
392    esac
393
394    mkdir -p ${xcachesrcdir}-${phpbasename}
395    cd ${xcachesrcdir}-${phpbasename} || exit
396    lndir ${xcachesrcdir} >/dev/null || true
397
398    pwd
399    run "$@"
400done
Note: See TracBrowser for help on using the repository browser.