本文整理汇总了C++中ASSERT_GE函数的典型用法代码示例。如果您正苦于以下问题:C++ ASSERT_GE函数的具体用法?C++ ASSERT_GE怎么用?C++ ASSERT_GE使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了ASSERT_GE函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: testSorting
void testSorting(std::vector<uint64_t> values, uint64_t memSize) {
char inFileName[] = "unsortedXXXXXX";
char outFileName[] = "sortedXXXXXX";
//create temporary input and output files
int fdIn = mkstemp(inFileName);
ASSERT_GE(fdIn, 0) << "unable to create input file: " << strerror(errno);
int fdOut = mkstemp(outFileName);
ASSERT_GE(fdOut, 0) << "unable to create output file: " << strerror(errno);
//store the input numbers into the input file
uint64_t bytesWritten = 0;
uint64_t bytesToBeWritten = values.size()*sizeof(uint64_t);
while(bytesWritten < bytesToBeWritten) {
int pwriteRet = pwrite(fdIn, &values[0], bytesToBeWritten - bytesWritten, bytesWritten);
ASSERT_GE(pwriteRet, 0) << "unable to write values to input file: " << strerror(errno);
bytesWritten += pwriteRet;
}
//sort the values
dbImpl::externalSort(fdIn, values.size(), fdOut, memSize);
//check the file size of the output file
struct stat outStat;
ASSERT_EQ(0, fstat(fdOut, &outStat)) << strerror(errno);
EXPECT_EQ(values.size()*sizeof(uint64_t), outStat.st_size);
//read back the results
std::unique_ptr<uint64_t[]> results(new uint64_t[values.size()]);
uint64_t bytesRead = 0;
uint64_t bytesToBeRead = values.size()*sizeof(uint64_t);
while(bytesRead < bytesToBeRead) {
int preadRet = pread(fdOut, &results[0], bytesToBeRead - bytesRead, bytesRead);
ASSERT_GE(preadRet, 0) << "unable to read values from output file: " << strerror(errno);
bytesRead += preadRet;
}
//they should be sorted now...
ASSERT_TRUE(std::is_sorted(&results[0], &results[values.size()]));
//close both file descriptors
//since they were created using O_TMPFILE, the files will be
//deleted automatically
ASSERT_EQ(0, close(fdOut)) << strerror(errno);
ASSERT_EQ(0, close(fdIn)) << strerror(errno);
//unlink the files
ASSERT_EQ(0, unlink(inFileName)) << strerror(errno);
ASSERT_EQ(0, unlink(outFileName)) << strerror(errno);
}
示例2: ASSERT_GE
void bar_widget::set_value(const std::string& key, const variant& value)
{
if(key == "segments") {
segments_ = value.as_int();
ASSERT_GE(segments_, 0);
init();
} else if(key == "segment_length") {
segment_length_ = value.as_int();
ASSERT_GT(segment_length_, 0);
init();
} else if(key == "tick_width") {
tick_width_ = value.as_int();
ASSERT_GT(tick_width_, 0);
init();
} else if(key == "scale") {
scale_ = value.as_decimal().as_float();
ASSERT_GT(scale_, 0.0f);
init();
} else if(key == "drain_rate") {
drain_rate_ = value.as_decimal().as_float();
ASSERT_GE(drain_rate_, 0.0);
} else if(key == "drained") {
int drain = value.as_int();
if(drain == drained_segments_) {
return;
}
int animation_start_position = segments_-drained_segments_;
animation_current_position_ = 0;
drained_segments_after_anim_ = drain;
if(drained_segments_after_anim_ < 0) {
drained_segments_after_anim_ = 0;
}
if(drained_segments_after_anim_ > segments_) {
drained_segments_after_anim_ = segments_;
}
int animation_end_position = segments_-drained_segments_after_anim_;
animation_end_point_unscaled_ = animation_end_position - animation_start_position;
animating_ = true;
init();
} else if(key == "max_width") {
bar_max_width_ = value.as_int();
init();
} else if(key == "animation_position") {
animation_current_position_ = value.as_decimal().as_float();
}
widget::set_value(key, value);
}
示例3: TEST_F
TEST_F(LayoutTextTest, WidthLengthBeyondLength) {
setBasicBody("x");
// Width may vary by platform and we just want to make sure it's something
// roughly reasonable.
float width = getBasicText()->width(0u, 2u, LayoutUnit(), LTR, false);
ASSERT_GE(width, 4.f);
ASSERT_LE(width, 20.f);
}
示例4: TEST_F
TEST_F(SemaphoreTest, timedwait) {
semaphore->post();
ASSERT_TRUE(semaphore->timedwait(0.1));
Time start_time(Time::now());
semaphore->timedwait(0.1);
Time elapsed_time(Time::now() - start_time);
ASSERT_GE(elapsed_time, Time(0.1));
}
示例5: TEST
TEST(BugKillingTests, RemoveLastBugIfDead) {
bug_list.clear();
bug_list.push_back(initBug(0, 0, EAST, 0));
bug_list.push_back(initBug(0, 1, EAST, MOVE_HEALTH * 3));
bug_list.push_back(initBug(0, 2, EAST, MOVE_HEALTH * 3));
bug_list.push_back(initBug(0, 3, EAST, 0));
initWorld();
moveBugs();
killDeadBugs();
ASSERT_EQ(bug_list.size(), 2);
ASSERT_EQ(world[0][1], EMPTY);
ASSERT_GE(world[0][2], 0);
ASSERT_GE(world[0][3], 0);
ASSERT_EQ(world[0][4], EMPTY);
}
示例6: TEST
/**
* The only process we are really guaranteed to have is this test process itself.
*/
TEST( Process_List_Test, find_our_process )
{
std::vector< PROCESSENTRY32W > v ;
initialize_process_list( v, our_process_by_name(), copy_all() ) ;
size_t size( v.size() );
EXPECT_EQ( 1u, size ); // Please, don't run multiple test executables simultaneously
ASSERT_GE( 1u, size );
}
示例7: TEST
/**
* Locate the PID of our process using the
*/
TEST(Process_List_Test, find_our_process_in_set)
{
std::vector<DWORD> v;
initialize_process_list(v, find_in_set, CopyPID());
size_t size(v.size());
EXPECT_EQ(size, 1u); // Please, don't run multiple test executables simultaneously
ASSERT_GE(size, 1u);
}
示例8: TEST
// Does the PRNG generate random integers with approximately even distribution?
TEST(UtilTest, CanGenerateRandomInts)
{
const int num_tests = 100000;
long long avg = 0;
for(size_t i = 0; i < num_tests; i++) {
int res = rend_rand();
ASSERT_LE(REND_RAND_MIN, res);
ASSERT_GE(REND_RAND_MAX, res);
avg += res;
}
avg /= num_tests;
long long mid = REND_RAND_MIN + (REND_RAND_MAX - REND_RAND_MIN) / 2;
long long err = mid / 100; // Test for +/-1% accuracy
ASSERT_LE(mid - err, avg);
ASSERT_GE(mid + err, avg);
}
示例9: TEST_F
TEST_F(Allocate, Zeroed)
{
void *zeroes = calloc(4096, 1);
for (unsigned int heapMask : m_allHeaps) {
SCOPED_TRACE(::testing::Message() << "heap " << heapMask);
int fds[16];
for (unsigned int i = 0; i < 16; i++) {
int map_fd = -1;
ASSERT_EQ(0, ion_alloc_fd(m_ionFd, 4096, 0, heapMask, 0, &map_fd));
ASSERT_GE(map_fd, 0);
void *ptr = NULL;
ptr = mmap(NULL, 4096, PROT_WRITE, MAP_SHARED, map_fd, 0);
ASSERT_TRUE(ptr != NULL);
memset(ptr, 0xaa, 4096);
ASSERT_EQ(0, munmap(ptr, 4096));
fds[i] = map_fd;
}
for (unsigned int i = 0; i < 16; i++) {
ASSERT_EQ(0, close(fds[i]));
}
int newIonFd = ion_open();
int map_fd = -1;
ASSERT_EQ(0, ion_alloc_fd(newIonFd, 4096, 0, heapMask, 0, &map_fd));
ASSERT_GE(map_fd, 0);
void *ptr = NULL;
ptr = mmap(NULL, 4096, PROT_READ, MAP_SHARED, map_fd, 0);
ASSERT_TRUE(ptr != NULL);
ASSERT_EQ(0, memcmp(ptr, zeroes, 4096));
ASSERT_EQ(0, munmap(ptr, 4096));
ASSERT_EQ(0, close(map_fd));
}
free(zeroes);
}
示例10: TEST
TEST(MoneyTest, comparisons) {
ASSERT_LT(change::Money(10, 99), change::Money(11, 10));
ASSERT_LE(change::Money(10, 99), change::Money(11, 10));
ASSERT_EQ(change::Money(10, 99), change::Money(10, 99));
ASSERT_LE(change::Money(10, 99), change::Money(10, 99));
ASSERT_GE(change::Money(10, 99), change::Money(10, 99));
ASSERT_GT(change::Money(11, 00), change::Money(10, 99));
ASSERT_GE(change::Money(11, 00), change::Money(10, 99));
EXPECT_TRUE(change::Money(10, 99) < change::Money(11, 10));
EXPECT_TRUE(change::Money(10, 99) <= change::Money(11, 10));
EXPECT_TRUE(change::Money(10, 99) == change::Money(10, 99));
EXPECT_TRUE(change::Money(10, 99) <= change::Money(10, 99));
EXPECT_TRUE(change::Money(10, 99) >= change::Money(10, 99));
EXPECT_TRUE(change::Money(11, 00) > change::Money(10, 99));
EXPECT_TRUE(change::Money(11, 00) >= change::Money(10, 99));
}
示例11: TEST_F
TEST_F( JihankiTest, GetJuiceList ) {
auto list = jihanki.insert(1000).second;
ASSERT_GE(list.size(), 1);
Juice tmp = list[0];
ASSERT_EQ("cola", tmp.name);
ASSERT_EQ(120, tmp.price);
}
示例12: TEST_F
TEST_F(StateMachineTests, AdvancedConnection) {
ASSERT_EQ(BST_MODE_CONNECTING_TO_BOOTSTRAP, bst_get_state());
bst_periodic();
ASSERT_EQ(BST_MODE_WAITING_FOR_DATA, bst_get_state());
prv_instance.options.retry_connecting_to_destination_network = 2;
prv_instance.options.need_advanced_connection = true;
{ // Send hello packet now
bst_udp_hello_receive_pkt_t pkt;
prv_generate_test_hello(&pkt);
bst_network_input((char*)&pkt,sizeof(bst_udp_hello_receive_pkt_t));
}
bst_periodic();
{ // Send bootstrap packet
bst_udp_bootstrap_receive_pkt_t pkt;
prv_generate_test_data(&pkt, true);
bst_network_input((char*)&pkt,sizeof(bst_udp_bootstrap_receive_pkt_t));
}
ASSERT_EQ(BST_MODE_WAITING_FOR_DATA, prv_instance.state.state);
bst_periodic();
ASSERT_EQ(BST_STATE_CONNECTED, bst_get_connection_state());
ASSERT_EQ(BST_MODE_CONNECTING_TO_DEST, prv_instance.state.state);
ASSERT_EQ(0, retry_advanced_connection);
// Expect no further connect to advanced until timeout_connecting_state_ms is over
for(unsigned i=0;i<5;++i) {
bst_periodic();
}
ASSERT_EQ(BST_STATE_CONNECTED, bst_get_connection_state());
ASSERT_GE(1, retry_advanced_connection);
// Expect second try to connect to advanced
addTimeMsOverwrite(prv_instance.options.timeout_connecting_state_ms+10);
ASSERT_GE(2, retry_advanced_connection);
next_connect_state = BST_STATE_CONNECTED_ADVANCED;
bst_periodic();
ASSERT_EQ(BST_STATE_CONNECTED_ADVANCED, bst_get_connection_state());
}
示例13: TEST_F
TEST_F(ConstexprMathTest, constexpr_add_overflow_clamped) {
for (int a = kInt8Min; a <= kInt8Max; a++) {
for (int b = kInt8Min; b <= kInt8Max; b++) {
int c = folly::constexpr_clamp(a + b, int(kInt8Min), int(kInt8Max));
int8_t a1 = a;
int8_t b1 = b;
int8_t c1 = folly::constexpr_add_overflow_clamped(a1, b1);
ASSERT_LE(c1, kInt8Max);
ASSERT_GE(c1, kInt8Min);
ASSERT_EQ(c1, c);
}
}
for (int a = 0; a <= kUInt8Max; a++) {
for (int b = 0; b <= kUInt8Max; b++) {
int c = folly::constexpr_clamp(a + b, 0, int(kUInt8Max));
uint8_t a1 = a;
uint8_t b1 = b;
uint8_t c1 = folly::constexpr_add_overflow_clamped(a1, b1);
ASSERT_LE(c1, kUInt8Max);
ASSERT_GE(c1, 0);
ASSERT_EQ(c1, c);
}
}
constexpr auto v1 =
folly::constexpr_add_overflow_clamped(int64_t(23), kInt64Max - 12);
EXPECT_EQ(kInt64Max, v1);
constexpr auto v2 =
folly::constexpr_add_overflow_clamped(int64_t(23), int64_t(12));
EXPECT_EQ(int64_t(35), v2);
constexpr auto v3 =
folly::constexpr_add_overflow_clamped(int64_t(-23), int64_t(12));
EXPECT_EQ(int64_t(-11), v3);
constexpr auto v4 =
folly::constexpr_add_overflow_clamped(int64_t(-23), int64_t(-12));
EXPECT_EQ(int64_t(-35), v4);
constexpr auto v5 =
folly::constexpr_add_overflow_clamped(uint64_t(23), kUInt64Max - 12);
EXPECT_EQ(kUInt64Max, v5);
}
示例14: advance_head
void safe_circular_char_buffer::
advance_head(const std::streamsize advance_len) {
ASSERT_GE(advance_len, 0);
ASSERT_LE(advance_len, size());
// advance the head forward as far as possible
head += advance_len;
// If head wraps around move head to begginning and then offset
if (head >= bufsize) head -= bufsize;
} // end of advance head
示例15: TEST
TEST(scheduledreporter, test) {
StubScheduledReporter scheduled_reporter(MetricRegistry::DEFAULT_REGISTRY(),
boost::chrono::milliseconds(1));
scheduled_reporter.start(boost::chrono::milliseconds(100));
boost::this_thread::sleep(boost::posix_time::seconds(1));
scheduled_reporter.stop();
ASSERT_LE((size_t)9, scheduled_reporter.invocation_count());
ASSERT_GE((size_t)11, scheduled_reporter.invocation_count());
}