diff options
author | David Robillard <d@drobilla.net> | 2018-11-24 13:44:03 +0100 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2018-11-24 13:44:03 +0100 |
commit | a7d83f19b08eb4c6f79a82fe60c2b86db13f4420 (patch) | |
tree | d9b620bfba1e7462df4ddb3f6225cc5216c0ca81 /tests/ingen_test.cpp | |
parent | d63edc742cebd685f8a05936682210aa5c1e69a9 (diff) | |
download | ingen-a7d83f19b08eb4c6f79a82fe60c2b86db13f4420.tar.gz ingen-a7d83f19b08eb4c6f79a82fe60c2b86db13f4420.tar.bz2 ingen-a7d83f19b08eb4c6f79a82fe60c2b86db13f4420.zip |
Squashed 'waflib/' changes from 6e726eb1..5ea8f99f
5ea8f99f Improve test output spacing
0e23b29f Raise exception when test suite fails to ensure non-zero exit status
d6de073b Show run time of unit tests
5b655541 Add short configure option for ultra-strict flags
4687ba6d Use gtest-like test output
258903d9 Fix failure count in test group summaries
da07e738 Fix verbose tests with Python 3
git-subtree-dir: waflib
git-subtree-split: 5ea8f99f6e1246079c1fe6bb590c38a53aadd40d
Diffstat (limited to 'tests/ingen_test.cpp')
-rw-r--r-- | tests/ingen_test.cpp | 223 |
1 files changed, 0 insertions, 223 deletions
diff --git a/tests/ingen_test.cpp b/tests/ingen_test.cpp deleted file mode 100644 index c0a7bd32..00000000 --- a/tests/ingen_test.cpp +++ /dev/null @@ -1,223 +0,0 @@ -/* - This file is part of Ingen. - Copyright 2007-2017 David Robillard <http://drobilla.net/> - - Ingen is free software: you can redistribute it and/or modify it under the - terms of the GNU Affero General Public License as published by the Free - Software Foundation, either version 3 of the License, or any later version. - - Ingen is distributed in the hope that it will be useful, but WITHOUT ANY - WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR - A PARTICULAR PURPOSE. See the GNU Affero General Public License for details. - - You should have received a copy of the GNU Affero General Public License - along with Ingen. If not, see <http://www.gnu.org/licenses/>. -*/ - -#include <signal.h> - -#include <cstdlib> -#include <iostream> -#include <string> - -#include <boost/optional.hpp> - -#include "raul/Path.hpp" - -#include "serd/serd.h" -#include "sord/sordmm.hpp" -#include "sratom/sratom.h" - -#include "ingen_config.h" - -#include "ingen/AtomReader.hpp" -#include "ingen/AtomWriter.hpp" -#include "ingen/Configuration.hpp" -#include "ingen/Configuration.hpp" -#include "ingen/EngineBase.hpp" -#include "ingen/Interface.hpp" -#include "ingen/Parser.hpp" -#include "ingen/Properties.hpp" -#include "ingen/Serialiser.hpp" -#include "ingen/Store.hpp" -#include "ingen/URIMap.hpp" -#include "ingen/World.hpp" -#include "ingen/filesystem.hpp" -#include "ingen/runtime_paths.hpp" -#include "ingen/types.hpp" - -#include "TestClient.hpp" - -using namespace std; -using namespace Ingen; - -World* world = nullptr; - -static void -ingen_try(bool cond, const char* msg) -{ - if (!cond) { - cerr << "ingen: Error: " << msg << endl; - delete world; - exit(EXIT_FAILURE); - } -} - -int -main(int argc, char** argv) -{ - set_bundle_path_from_code((void*)&ingen_try); - - // Create world - try { - world = new World(nullptr, nullptr, nullptr); - world->load_configuration(argc, argv); - } catch (std::exception& e) { - cout << "ingen: " << e.what() << endl; - return EXIT_FAILURE; - } - - // Get mandatory command line arguments - const Atom& load = world->conf().option("load"); - const Atom& execute = world->conf().option("execute"); - if (!load.is_valid() || !execute.is_valid()) { - cerr << "Usage: ingen_test --load START_GRAPH --execute COMMANDS_FILE" << endl; - return EXIT_FAILURE; - } - - // Get start graph and commands file options - const char* load_path = (const char*)load.get_body(); - char* real_start_graph = realpath(load_path, nullptr); - if (!real_start_graph) { - cerr << "error: initial graph '" << load_path << "' does not exist" << endl; - return EXIT_FAILURE; - } - - const std::string start_graph = real_start_graph; - const FilePath cmds_file_path = (const char*)execute.get_body(); - free(real_start_graph); - - // Load modules - ingen_try(world->load_module("server"), - "Unable to load server module"); - - // Initialise engine - ingen_try(bool(world->engine()), - "Unable to create engine"); - world->engine()->init(48000.0, 4096, 4096); - world->engine()->activate(); - - // Load graph - if (!world->parser()->parse_file(world, world->interface().get(), start_graph)) { - cerr << "error: failed to load initial graph " << start_graph << endl; - return EXIT_FAILURE; - } - world->engine()->flush_events(std::chrono::milliseconds(20)); - - // Read commands - - LV2_URID_Map* map = &world->uri_map().urid_map_feature()->urid_map; - Sratom* sratom = sratom_new(map); - - sratom_set_object_mode(sratom, SRATOM_OBJECT_MODE_BLANK_SUBJECT); - - LV2_Atom_Forge forge; - lv2_atom_forge_init(&forge, map); - - AtomForgeSink out(&forge); - - // AtomReader to read commands from a file and send them to engine - AtomReader atom_reader(world->uri_map(), - world->uris(), - world->log(), - *world->interface().get()); - - // AtomWriter to serialise responses from the engine - SPtr<Interface> client(new TestClient(world->log())); - - world->interface()->set_respondee(client); - world->engine()->register_client(client); - - SerdURI cmds_base; - SerdNode cmds_file_uri = serd_node_new_file_uri( - (const uint8_t*)cmds_file_path.c_str(), - nullptr, &cmds_base, true); - Sord::Model* cmds = new Sord::Model(*world->rdf_world(), - (const char*)cmds_file_uri.buf); - SerdEnv* env = serd_env_new(&cmds_file_uri); - cmds->load_file(env, SERD_TURTLE, cmds_file_path); - Sord::Node nil; - int n_events = 0; - for (;; ++n_events) { - std::string subject_str = (fmt("msg%1%") % n_events).str(); - Sord::URI subject(*world->rdf_world(), subject_str, - (const char*)cmds_file_uri.buf); - Sord::Iter iter = cmds->find(subject, nil, nil); - if (iter.end()) { - break; - } - - out.clear(); - sratom_read(sratom, &forge, world->rdf_world()->c_obj(), - cmds->c_obj(), subject.c_obj()); - -#if 0 - const LV2_Atom* atom = out.atom(); - cerr << "READ " << atom->size << " BYTES" << endl; - cerr << sratom_to_turtle( - sratom, - &world->uri_map().urid_unmap_feature()->urid_unmap, - (const char*)cmds_file_uri.buf, - NULL, NULL, atom->type, atom->size, LV2_ATOM_BODY(atom)) << endl; -#endif - - if (!atom_reader.write(out.atom(), n_events + 1)) { - return EXIT_FAILURE; - } - - world->engine()->flush_events(std::chrono::milliseconds(20)); - } - - delete cmds; - - // Save resulting graph - auto r = world->store()->find(Raul::Path("/")); - const std::string base = cmds_file_path.stem(); - const std::string out_name = base.substr(0, base.find('.')) + ".out.ingen"; - const FilePath out_path = filesystem::current_path() / out_name; - world->serialiser()->write_bundle(r->second, URI(out_path)); - - // Undo every event (should result in a graph identical to the original) - for (int i = 0; i < n_events; ++i) { - world->interface()->undo(); - world->engine()->flush_events(std::chrono::milliseconds(20)); - } - - // Save completely undone graph - r = world->store()->find(Raul::Path("/")); - const std::string undo_name = base.substr(0, base.find('.')) + ".undo.ingen"; - const FilePath undo_path = filesystem::current_path() / undo_name; - world->serialiser()->write_bundle(r->second, URI(undo_path)); - - // Redo every event (should result in a graph identical to the pre-undo output) - for (int i = 0; i < n_events; ++i) { - world->interface()->redo(); - world->engine()->flush_events(std::chrono::milliseconds(20)); - } - - // Save completely redone graph - r = world->store()->find(Raul::Path("/")); - const std::string redo_name = base.substr(0, base.find('.')) + ".redo.ingen"; - const FilePath redo_path = filesystem::current_path() / redo_name; - world->serialiser()->write_bundle(r->second, URI(redo_path)); - - serd_env_free(env); - sratom_free(sratom); - serd_node_free(&cmds_file_uri); - - // Shut down - world->engine()->deactivate(); - - delete world; - return EXIT_SUCCESS; -} |