Path: blob/main/contrib/kyua/drivers/scan_results.cpp
39478 views
// Copyright 2011 The Kyua Authors.1// All rights reserved.2//3// Redistribution and use in source and binary forms, with or without4// modification, are permitted provided that the following conditions are5// met:6//7// * Redistributions of source code must retain the above copyright8// notice, this list of conditions and the following disclaimer.9// * Redistributions in binary form must reproduce the above copyright10// notice, this list of conditions and the following disclaimer in the11// documentation and/or other materials provided with the distribution.12// * Neither the name of Google Inc. nor the names of its contributors13// may be used to endorse or promote products derived from this software14// without specific prior written permission.15//16// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS17// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT18// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR19// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT20// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,21// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT22// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,23// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY24// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT25// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE26// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.2728#include "drivers/scan_results.hpp"2930#include "engine/filters.hpp"31#include "model/context.hpp"32#include "model/test_case.hpp"33#include "model/test_program.hpp"34#include "store/read_backend.hpp"35#include "store/read_transaction.hpp"36#include "utils/defs.hpp"3738namespace fs = utils::fs;394041/// Pure abstract destructor.42drivers::scan_results::base_hooks::~base_hooks(void)43{44}454647/// Callback executed before any operation is performed.48void49drivers::scan_results::base_hooks::begin(void)50{51}525354/// Callback executed after all operations are performed.55void56drivers::scan_results::base_hooks::end(const result& /* r */)57{58}596061/// Executes the operation.62///63/// \param store_path The path to the database store.64/// \param raw_filters The test case filters as provided by the user.65/// \param hooks The hooks for this execution.66///67/// \returns A structure with all results computed by this driver.68drivers::scan_results::result69drivers::scan_results::drive(const fs::path& store_path,70const std::set< engine::test_filter >& raw_filters,71base_hooks& hooks)72{73engine::filters_state filters(raw_filters);7475store::read_backend db = store::read_backend::open_ro(store_path);76store::read_transaction tx = db.start_read();7778hooks.begin();7980const model::context context = tx.get_context();81hooks.got_context(context);8283store::results_iterator iter = tx.get_results();84while (iter) {85// TODO(jmmv): We should be filtering at the test case level for86// efficiency, but that means we would need to execute more than one87// query on the database and our current interfaces don't support that.88//89// Reuse engine::filters_state for the time being because it is simpler90// and we get tracking of unmatched filters "for free".91const model::test_program_ptr test_program = iter.test_program();92if (filters.match_test_program(test_program->relative_path())) {93const model::test_case& test_case = test_program->find(94iter.test_case_name());95if (filters.match_test_case(test_program->relative_path(),96test_case.name())) {97hooks.got_result(iter);98}99}100++iter;101}102103result r(filters.unused());104hooks.end(r);105return r;106}107108109