xref: /minix3/external/bsd/kyua-cli/dist/engine/test_case.hpp (revision 84d9c625bfea59e274550651111ae9edfdc40fbd)
111be35a1SLionel Sambuc // Copyright 2010 Google Inc.
211be35a1SLionel Sambuc // All rights reserved.
311be35a1SLionel Sambuc //
411be35a1SLionel Sambuc // Redistribution and use in source and binary forms, with or without
511be35a1SLionel Sambuc // modification, are permitted provided that the following conditions are
611be35a1SLionel Sambuc // met:
711be35a1SLionel Sambuc //
811be35a1SLionel Sambuc // * Redistributions of source code must retain the above copyright
911be35a1SLionel Sambuc //   notice, this list of conditions and the following disclaimer.
1011be35a1SLionel Sambuc // * Redistributions in binary form must reproduce the above copyright
1111be35a1SLionel Sambuc //   notice, this list of conditions and the following disclaimer in the
1211be35a1SLionel Sambuc //   documentation and/or other materials provided with the distribution.
1311be35a1SLionel Sambuc // * Neither the name of Google Inc. nor the names of its contributors
1411be35a1SLionel Sambuc //   may be used to endorse or promote products derived from this software
1511be35a1SLionel Sambuc //   without specific prior written permission.
1611be35a1SLionel Sambuc //
1711be35a1SLionel Sambuc // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
1811be35a1SLionel Sambuc // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
1911be35a1SLionel Sambuc // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
2011be35a1SLionel Sambuc // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
2111be35a1SLionel Sambuc // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
2211be35a1SLionel Sambuc // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
2311be35a1SLionel Sambuc // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
2411be35a1SLionel Sambuc // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
2511be35a1SLionel Sambuc // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
2611be35a1SLionel Sambuc // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
2711be35a1SLionel Sambuc // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2811be35a1SLionel Sambuc 
2911be35a1SLionel Sambuc /// \file engine/test_case.hpp
3011be35a1SLionel Sambuc /// Interface to interact with test cases.
3111be35a1SLionel Sambuc 
3211be35a1SLionel Sambuc #if !defined(ENGINE_TEST_CASE_HPP)
3311be35a1SLionel Sambuc #define ENGINE_TEST_CASE_HPP
3411be35a1SLionel Sambuc 
3511be35a1SLionel Sambuc #include <ostream>
3611be35a1SLionel Sambuc #include <string>
3711be35a1SLionel Sambuc 
3811be35a1SLionel Sambuc #include "engine/metadata.hpp"
3911be35a1SLionel Sambuc #include "utils/config/tree.hpp"
4011be35a1SLionel Sambuc #include "utils/fs/path.hpp"
4111be35a1SLionel Sambuc #include "utils/optional.hpp"
42*84d9c625SLionel Sambuc #include "utils/shared_ptr.hpp"
4311be35a1SLionel Sambuc 
4411be35a1SLionel Sambuc namespace engine {
4511be35a1SLionel Sambuc 
4611be35a1SLionel Sambuc 
4711be35a1SLionel Sambuc class test_result;
4811be35a1SLionel Sambuc class test_program;
4911be35a1SLionel Sambuc 
5011be35a1SLionel Sambuc 
5111be35a1SLionel Sambuc /// Hooks to introspect the execution of a test case.
5211be35a1SLionel Sambuc ///
5311be35a1SLionel Sambuc /// There is no guarantee that these hooks will be called during the execution
5411be35a1SLionel Sambuc /// of the test case.  There are conditions in which they don't make sense.
5511be35a1SLionel Sambuc ///
5611be35a1SLionel Sambuc /// Note that this class is not abstract.  All hooks have default, empty
5711be35a1SLionel Sambuc /// implementations.  The purpose of this is to simplify some tests that need to
5811be35a1SLionel Sambuc /// pass hooks but that are not interested in the results.  We might want to
5911be35a1SLionel Sambuc /// rethink this and provide an "empty subclass" of a base abstract template.
6011be35a1SLionel Sambuc class test_case_hooks {
6111be35a1SLionel Sambuc public:
6211be35a1SLionel Sambuc     virtual ~test_case_hooks(void);
6311be35a1SLionel Sambuc 
6411be35a1SLionel Sambuc     virtual void got_stdout(const utils::fs::path&);
6511be35a1SLionel Sambuc     virtual void got_stderr(const utils::fs::path&);
6611be35a1SLionel Sambuc };
6711be35a1SLionel Sambuc 
6811be35a1SLionel Sambuc 
6911be35a1SLionel Sambuc /// Representation of a test case.
7011be35a1SLionel Sambuc class test_case {
7111be35a1SLionel Sambuc     struct impl;
7211be35a1SLionel Sambuc 
7311be35a1SLionel Sambuc     /// Pointer to the shared internal implementation.
74*84d9c625SLionel Sambuc     std::shared_ptr< impl > _pimpl;
7511be35a1SLionel Sambuc 
7611be35a1SLionel Sambuc public:
7711be35a1SLionel Sambuc     test_case(const std::string&, const test_program&,
7811be35a1SLionel Sambuc               const std::string&, const metadata&);
7911be35a1SLionel Sambuc     test_case(const std::string&, const test_program&,
8011be35a1SLionel Sambuc               const std::string&, const std::string&,
8111be35a1SLionel Sambuc               const engine::test_result&);
8211be35a1SLionel Sambuc     ~test_case(void);
8311be35a1SLionel Sambuc 
8411be35a1SLionel Sambuc     const std::string& interface_name(void) const;
8511be35a1SLionel Sambuc     const test_program& container_test_program(void) const;
8611be35a1SLionel Sambuc     const std::string& name(void) const;
8711be35a1SLionel Sambuc     const metadata& get_metadata(void) const;
8811be35a1SLionel Sambuc     utils::optional< test_result > fake_result(void) const;
8911be35a1SLionel Sambuc 
9011be35a1SLionel Sambuc     bool operator==(const test_case&) const;
9111be35a1SLionel Sambuc     bool operator!=(const test_case&) const;
9211be35a1SLionel Sambuc };
9311be35a1SLionel Sambuc 
9411be35a1SLionel Sambuc 
9511be35a1SLionel Sambuc std::ostream& operator<<(std::ostream&, const test_case&);
9611be35a1SLionel Sambuc 
9711be35a1SLionel Sambuc 
9811be35a1SLionel Sambuc /// Pointer to a test case.
99*84d9c625SLionel Sambuc typedef std::shared_ptr< test_case > test_case_ptr;
10011be35a1SLionel Sambuc 
10111be35a1SLionel Sambuc 
10211be35a1SLionel Sambuc test_result debug_test_case(const test_case*, const utils::config::tree&,
10311be35a1SLionel Sambuc                             test_case_hooks&, const utils::fs::path&,
10411be35a1SLionel Sambuc                             const utils::fs::path&, const utils::fs::path&);
10511be35a1SLionel Sambuc test_result run_test_case(const test_case*, const utils::config::tree&,
10611be35a1SLionel Sambuc                           test_case_hooks&, const utils::fs::path&);
10711be35a1SLionel Sambuc 
10811be35a1SLionel Sambuc 
10911be35a1SLionel Sambuc }  // namespace engine
11011be35a1SLionel Sambuc 
11111be35a1SLionel Sambuc 
11211be35a1SLionel Sambuc #endif  // !defined(ENGINE_TEST_CASE_HPP)
113