blob: 2a716e665ef63f0c2f837aba0fc4df3f7d239180 [file] [log] [blame]
Ivo Creusen55de08e2018-09-03 11:49:27 +02001/*
2 * Copyright (c) 2018 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#ifndef API_TEST_NETEQ_SIMULATOR_FACTORY_H_
12#define API_TEST_NETEQ_SIMULATOR_FACTORY_H_
13
14#include <memory>
Ivo Creusen5ec61562019-03-20 10:52:18 +010015#include <string>
Ivo Creusen55de08e2018-09-03 11:49:27 +020016
Ivo Creusen5ec61562019-03-20 10:52:18 +010017#include "absl/strings/string_view.h"
Ivo Creusen26d52e12020-03-24 15:59:26 +010018#include "absl/types/optional.h"
Ivo Creusencee751a2020-01-16 17:17:09 +010019#include "api/neteq/neteq_factory.h"
Ivo Creusen55de08e2018-09-03 11:49:27 +020020#include "api/test/neteq_simulator.h"
21
22namespace webrtc {
23namespace test {
24
25class NetEqTestFactory;
26
27class NetEqSimulatorFactory {
28 public:
29 NetEqSimulatorFactory();
30 ~NetEqSimulatorFactory();
Ivo Creusen5ec61562019-03-20 10:52:18 +010031 struct Config {
Ivo Creusen99a20962019-10-07 13:18:18 +020032 // The maximum allowed number of packets in the jitter buffer.
Ivo Creusen5ec61562019-03-20 10:52:18 +010033 int max_nr_packets_in_buffer = 0;
Ivo Creusen99a20962019-10-07 13:18:18 +020034 // The number of audio packets to insert at the start of the simulation.
35 // Since the simulation is done with a replacement audio file, these
36 // artificial packets will take a small piece of that replacement audio.
37 int initial_dummy_packets = 0;
38 // The number of simulation steps to skip at the start of the simulation.
39 // This removes incoming packets and GetAudio events from the start of the
40 // simulation, until the requested number of GetAudio events has been
41 // removed.
42 int skip_get_audio_events = 0;
43 // A WebRTC field trial string to be used during the simulation.
44 std::string field_trial_string;
Ivo Creusen26d52e12020-03-24 15:59:26 +010045 // A filename for the generated output audio file.
46 absl::optional<std::string> output_audio_filename;
Ivo Creusen47156e22020-10-13 15:17:32 +020047 // A filename for the python plot.
48 absl::optional<std::string> python_plot_filename;
49 // A filename for the text log.
50 absl::optional<std::string> text_log_filename;
Ivo Creusencee751a2020-01-16 17:17:09 +010051 // A custom NetEqFactory can be used.
52 NetEqFactory* neteq_factory = nullptr;
Ivo Creusen5ec61562019-03-20 10:52:18 +010053 };
Ivo Creusen5ec61562019-03-20 10:52:18 +010054 std::unique_ptr<NetEqSimulator> CreateSimulatorFromFile(
55 absl::string_view event_log_filename,
56 absl::string_view replacement_audio_filename,
57 Config simulation_config);
58 // The same as above, but pass the file contents as a string.
59 std::unique_ptr<NetEqSimulator> CreateSimulatorFromString(
60 absl::string_view event_log_file_contents,
61 absl::string_view replacement_audio_file,
62 Config simulation_config);
Ivo Creusen55de08e2018-09-03 11:49:27 +020063
64 private:
65 std::unique_ptr<NetEqTestFactory> factory_;
66};
67
68} // namespace test
69} // namespace webrtc
70
71#endif // API_TEST_NETEQ_SIMULATOR_FACTORY_H_