* tests/*
* website/*
* dropped 'tst'/'ts'/'test' from most
filenames inside main 'tests' dir. 8 chars will
allow for more descriptive names than 4-5.
Some renamed to use the new space.
Similar ones will now be much close together
and easier to lookup in alphabetical order.
; NOTE: Perhaps a new distinction would be useful,
for those which are indeed tests for the
compiler or PP, f.e. these:
declare.prg, dupvars.prg, keywords.prg, linecont.prg,
lnlenli1.prg, lnlenli2.prg, pp.prg, pragma.prg, warnings.prg
; List of changes:
tests/ac_test.prg -> achoice.prg
tests/ac_test2.prg -> achoice2.prg
tests/adirtest.prg -> adir.prg
tests/ainstest.prg -> ains.prg
tests/tstalias.prg -> aliasrt.prg
tests/altdtest.prg -> altd.prg
tests/atest.prg -> array.prg
tests/tstasort.prg -> asort.prg
tests/boxtst2.prg -> box2.prg
tests/boxtest.prg -> box3.prg
tests/testbrdb.prg -> browse.prg
tests/tstblock.prg -> cblock.prg
tests/testcdx.prg -> cdx.prg
tests/tstchbx.prg -> checkbox.prg
tests/testcls.prg -> cls.prg
tests/tscmdarg.c -> cmdarg.c
tests/tstcolor.prg -> color.prg
tests/testcom1.prg -> com.prg
tests/cursrtst.prg -> cursor.prg
tests/dttest.prg -> datetime.prg
tests/dbevalts.prg -> dbeval.prg
tests/testdbf.prg -> dbf.prg
tests/tstdbi.prg -> dbi.prg
tests/debugtst.prg -> debug.prg
tests/testdecl.prg -> declare.prg
tests/testid.prg -> define.prg
tests/delimtst.prg -> delim.prg
tests/devtest.prg -> dev.prg
tests/dirtest.prg -> directry.prg
tests/tstdspac.prg -> diskspac.prg
tests/disptest.prg -> disp.prg
tests/testdyn.c -> dyn.c
tests/testdyn1.prg -> dyn.prg
tests/testdyn.prg -> dynwin.prg
tests/testerro.prg -> errsys.prg
tests/exittest.prg -> exit.prg
tests/iotest.prg -> fileio.prg
tests/iotest2.prg -> fileio2.prg
tests/fortest.prg -> for.prg
tests/testfor.prg -> for2.prg
tests/testget.prg -> get.prg
tests/tstgtapi.c -> gtapi.c
tests/gtstdtst.prg -> gtstd.prg
tests/hbdoctst.prg -> hbdoc.prg
tests/testhrb.prg -> hrb.prg
tests/hsxtest.prg -> hsx.prg
tests/testhtml.prg -> html.prg
tests/testidle.prg -> idle.prg
tests/testinit.prg -> initproc.prg
tests/inkeytst.prg -> inkey.prg
tests/testlbl.prg -> lbl.prg
tests/tstmacro.prg -> macro.prg
tests/mathtest.prg -> math.prg
tests/testmem.prg -> mem.prg
tests/memtst.prg -> memmgr.prg
tests/menutest.prg -> menuto.prg
tests/testmny.prg -> money.prg
tests/mousetst.prg -> mouse.prg
tests/testntx.prg -> ntx.prg
tests/testop.prg -> op.prg
tests/testpers.prg -> persist.prg
tests/testpp.prg -> pp.prg
tests/testpre.prg -> ppapi.prg
tests/tstprag.prg -> pragma.prg
tests/testprof.prg -> profiler.prg
tests/testrdd.prg -> rdd.prg
tests/testrdd2.prg -> rdd2.prg
tests/testread.prg -> read.prg
tests/regextst.prg -> regex2.prg
tests/testrpt.prg -> rpt.prg
tests/sbartest.prg -> sbar.prg
tests/sdf_test.prg -> sdf.prg
tests/set_test.prg -> set.prg
tests/videotst.prg -> setmode.prg
tests/testsha1.prg -> sha1.prg
tests/testsha2.prg -> sha2.prg
tests/teststr.prg -> str.prg
tests/testbrw.prg -> tbrowse.prg
tests/transtst.prg -> transfrm.prg
tests/tstuse.prg -> use.prg
tests/testvars.prg -> vars.prg
tests/vidtest.prg -> video.prg
tests/testwarn.prg -> warnings.prg
* tests/read.prg
* use K_* value
109 lines
2.4 KiB
Plaintext
109 lines
2.4 KiB
Plaintext
/*
|
|
* $Id$
|
|
*/
|
|
|
|
/* Test code for the harbour profiler API and the profile reporting classes */
|
|
|
|
#include "inkey.ch"
|
|
|
|
PROCEDURE Main()
|
|
|
|
LOCAL oProfile := HBProfile():new()
|
|
LOCAL n
|
|
|
|
// Turn on profiling.
|
|
__SetProfiler( .T. )
|
|
|
|
// Make sure we've got something to see timewise.
|
|
DrawScreen( "Doing nothing for a couple of seconds" )
|
|
DoNothingForTwoSeconds()
|
|
|
|
// Make sure we've got something to see callwise.
|
|
FOR n := 1 TO 500
|
|
CallMe500Times()
|
|
NEXT
|
|
|
|
// Take a profile snapshot.
|
|
oProfile:gather()
|
|
|
|
// Report on calls greater than 0
|
|
DrawScreen( "All methods/functions called one or more times" )
|
|
MemoEdit( HBProfileReportToString():new( oProfile:callSort() ):generate( {| o | o:nCalls > 0 } ), 1,,,, .F. )
|
|
|
|
// Sorted by name
|
|
DrawScreen( "All methods/functions called one or more times, sorted by name" )
|
|
MemoEdit( HBProfileReportToString():new( oProfile:nameSort() ):generate( {| o | o:nCalls > 0 } ), 1,,,, .F. )
|
|
|
|
// Sorted by time
|
|
DrawScreen( "All methods/functions taking measurable time, sorted by time" )
|
|
MemoEdit( HBProfileReportToString():new( oProfile:timeSort() ):generate( {| o | o:nTicks > 0 } ), 1,,,, .F. )
|
|
|
|
// TBrowse all calls greater than 0
|
|
DrawScreen( "TBrowse all methods/functions called one or more times" )
|
|
Browser( HBProfileReportToTBrowse():new( oProfile:callSort() ):generate( {| o | o:nCalls > 0 }, 1 ) )
|
|
|
|
// Some closing stats
|
|
DrawScreen( "Totals" )
|
|
@ 2, 0 SAY " Total Calls: " + Str( oProfile:totalCalls() )
|
|
@ 3, 0 SAY " Total Ticks: " + Str( oProfile:totalTicks() )
|
|
@ 4, 0 SAY "Total Seconds: " + Str( oProfile:totalSeconds() )
|
|
|
|
RETURN
|
|
|
|
STATIC PROCEDURE DrawScreen( cTitle )
|
|
|
|
CLS
|
|
|
|
@ 0, 0 SAY PadR( cTitle, MaxCol() + 1 ) COLOR "N/W"
|
|
|
|
RETURN
|
|
|
|
PROCEDURE DoNothingForTwoSeconds()
|
|
|
|
Inkey( 2 )
|
|
|
|
RETURN
|
|
|
|
PROCEDURE CallMe500Times()
|
|
|
|
RETURN
|
|
|
|
STATIC PROCEDURE Browser( oBrowse )
|
|
|
|
LOCAL lBrowsing := .T.
|
|
|
|
DO WHILE lBrowsing
|
|
|
|
oBrowse:forceStable()
|
|
|
|
SWITCH Inkey( 0 )
|
|
CASE K_ESC
|
|
lBrowsing := .F.
|
|
EXIT
|
|
CASE K_DOWN
|
|
oBrowse:down()
|
|
EXIT
|
|
CASE K_UP
|
|
oBrowse:up()
|
|
EXIT
|
|
CASE K_LEFT
|
|
oBrowse:left()
|
|
EXIT
|
|
CASE K_RIGHT
|
|
oBrowse:right()
|
|
EXIT
|
|
CASE K_PGDN
|
|
oBrowse:pageDown()
|
|
EXIT
|
|
CASE K_PGUP
|
|
oBrowse:pageUp()
|
|
EXIT
|
|
|
|
// And so on.... (not really necessary for this test)
|
|
|
|
ENDSWITCH
|
|
|
|
ENDDO
|
|
|
|
RETURN
|