當前位置: 首頁>>代碼示例>>C++>>正文


C++ ASSERT_GE函數代碼示例

本文整理匯總了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);
}
開發者ID:vogelsgesang,項目名稱:dbimpl,代碼行數:47,代碼來源:externalSortTest.cpp

示例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);
	}
開發者ID:emmasteimann,項目名稱:frogatto,代碼行數:47,代碼來源:bar_widget.cpp

示例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);
}
開發者ID:mirror,項目名稱:chromium,代碼行數:8,代碼來源:LayoutTextTest.cpp

示例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));
}
開發者ID:respu,項目名稱:yield,代碼行數:8,代碼來源:semaphore_test.cpp

示例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);
}
開發者ID:lemonade512,項目名稱:EE312,代碼行數:17,代碼來源:main.cpp

示例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 );
}
開發者ID:suninf,項目名稱:adblockplusie,代碼行數:11,代碼來源:process_test.cpp

示例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);
}
開發者ID:erikvold,項目名稱:new-adblockplusie,代碼行數:11,代碼來源:process_test.cpp

示例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);
}
開發者ID:lmurray,項目名稱:rendasaurus,代碼行數:18,代碼來源:util.cpp

示例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);

}
開發者ID:00zhengfu00,項目名稱:platform_system_core,代碼行數:46,代碼來源:allocate_test.cpp

示例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)); 
}
開發者ID:mgalushka,項目名稱:cpp-start,代碼行數:17,代碼來源:ChangeTest.cpp

示例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);
}
開發者ID:datsuns,項目名稱:jihanki,代碼行數:8,代碼來源:TestJihanki.cpp

示例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());
}
開發者ID:Openhab-Nodes,項目名稱:libNodesBootstrap,代碼行數:46,代碼來源:statemachine_tests.cpp

示例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);
}
開發者ID:JacobMao,項目名稱:folly,代碼行數:45,代碼來源:ConstexprMathTest.cpp

示例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
開發者ID:Bhushan1002,項目名稱:SFrame,代碼行數:9,代碼來源:safe_circular_char_buffer.cpp

示例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());
}
開發者ID:QuantScientist3,項目名稱:cppmetrics,代碼行數:9,代碼來源:test_scheduled_reporter.cpp


注:本文中的ASSERT_GE函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。