📄 timevalue.cpp
字号:
//%2006//////////////////////////////////////////////////////////////////////////// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;// IBM Corp.; EMC Corporation, The Open Group.// Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.// Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;// EMC Corporation; VERITAS Software Corporation; The Open Group.// Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;// EMC Corporation; Symantec Corporation; The Open Group.//// Permission is hereby granted, free of charge, to any person obtaining a copy// of this software and associated documentation files (the "Software"), to// deal in the Software without restriction, including without limitation the// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or// sell copies of the Software, and to permit persons to whom the Software is// furnished to do so, subject to the following conditions:// // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.////==============================================================================//// Author: Mike Brasher (mbrasher@bmc.com)//// Modified By:////%/////////////////////////////////////////////////////////////////////////////#include <iostream>#include <Pegasus/Common/PegasusAssert.h>#include <Pegasus/Common/TimeValue.h>#include <Pegasus/Common/System.h>PEGASUS_USING_STD;PEGASUS_USING_PEGASUS;static char * verbose;int main(int argc, char** argv){ verbose = getenv("PEGASUS_TEST_VERBOSE"); TimeValue tv0( 3, 100000); // set to 3 sec, 100,000 microseconds Uint32 ms = tv0.toMilliseconds(); if (verbose) { cout << "milliseconds=" << ms << endl; } PEGASUS_TEST_ASSERT(ms == (3 * 1000) + 100); tv0.setSeconds(4); tv0.setMicroseconds(200000); ms = tv0.toMilliseconds(); PEGASUS_TEST_ASSERT(ms == (4 * 1000) + 200); // Test the tomilliseconds function TimeValue tvx(1,0); PEGASUS_TEST_ASSERT(tvx.toMilliseconds() == 1 * 1000); tvx.setSeconds(2); PEGASUS_TEST_ASSERT(tvx.toMilliseconds() == 2 * 1000); tvx.setMicroseconds(500000); PEGASUS_TEST_ASSERT(tvx.toMilliseconds() == ((2 * 1000) + 500)); // Test time difference between two getCurrentTime calls. TimeValue tv1 = TimeValue::getCurrentTime(); System::sleep(5); TimeValue tv2 = TimeValue::getCurrentTime(); if (verbose) { cout << "tv1 " << tv1.getSeconds() << " Seconds " << tv1.getMicroseconds() << " microseconds " << tv1.toMilliseconds() << " total milliseconds" << endl; cout << "tv2 " << tv2.getSeconds() << " Seconds " << tv2.getMicroseconds() << " microseconds " << tv2.toMilliseconds() << " total milliseconds" << endl; } Uint32 milliseconds = tv2.toMilliseconds() - tv1.toMilliseconds(); if (verbose) cout << "milliseconds=" << milliseconds << endl; PEGASUS_TEST_ASSERT(milliseconds >= 4500 && milliseconds <= 5500); if (verbose) cout << System::getCurrentASCIITime() << endl; cout << argv[0] << " +++++ passed all tests" << endl; return 0;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -