zoukankan      html  css  js  c++  java
  • leveldb分析——单元测试工具

    leveldb中自己实现了一个简单的单元测试工具,下面是一个对CRC类测试的一个例子

    class CRC { };
    TEST(CRC, Extend) {
       ASSERT_EQ(Value("hello world", 11),
       Extend(Value("hello ", 6), "world", 5));
    }

     int main(int argc, char** argv) {
       return leveldb::test::RunAllTests();
     }

    TEST() 和RunAllTests()空间是怎么实现的呢?我们来看看源码:

    #define TEST(base,name)                                                 
    class TCONCAT(_Test_,name) : public base {                              
     public:                                                                
      void _Run();                                                          
      static void _RunIt() {                                                
        TCONCAT(_Test_,name) t;                                             
        t._Run();                                                           
      }                                                                     
    };                                                                      
    bool TCONCAT(_Test_ignored_,name) =                                     
      ::leveldb::test::RegisterTest(#base, #name, &TCONCAT(_Test_,name)::_RunIt); 
    void TCONCAT(_Test_,name)::_Run()

     对上面的测试程序实际展开后如下:

    class _Test_Extend : public CRC {
     public:
      void _Run();
      static void _RunIt(){
        _Test_Extend t;
        t._Run();
      }
    };
    bool _Test_ignored_Extend = ::leveldb::test::Register("CRC","Extend",&_Test_Extend::_RunIt());
    void _Test_Extend::Run(){
       ASSERT_EQ(Value("hello world", 11),
       Extend(Value("hello ", 6), "world", 5));
    }

    注册过程:

    struct Test {
      const char* base;
      const char* name;
      void (*func)();
    };
    std::vector<Test>* tests;
    }
    
    bool RegisterTest(const char* base, const char* name, void (*func)()) {
      if (tests == NULL) {
        tests = new std::vector<Test>;
      }
      Test t;
      t.base = base;
      t.name = name;
      t.func = func;
      tests->push_back(t);
      return true;
    }

     运行过程:

    int RunAllTests() {
      int num = 0;
      if (tests != NULL) {
        for (int i = 0; i < tests->size(); i++) {
          const Test& t = (*tests)[i];
          }
          fprintf(stderr, "==== Test %s.%s
    ", t.base, t.name);
          (*t.func)();
          ++num;
        }
      }
      fprintf(stderr, "==== PASSED %d tests
    ", num);
      return 0;
    }
  • 相关阅读:
    【bzoj4240】有趣的家庭菜园
    「洛谷 P1801」黑匣子
    「SDOI 2009」Elaxia的路线
    NOIP 2016【蚯蚓】
    NOIP 2014【斗地主】
    尺取法
    POJ 3169 Layout
    51nod【1196】字符串的数量
    51nod1671【货物运输】
    hihocoder1075【开锁魔法】
  • 原文地址:https://www.cnblogs.com/xey-csu/p/5149797.html
Copyright © 2011-2022 走看看