| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 | /** * Copyright (c) 2019 Paul-Louis Ageneau * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at https://mozilla.org/MPL/2.0/. */#include <chrono>#include <iostream>#include <thread>#include "test.hpp"#include <rtc/rtc.hpp>using namespace std;using namespace chrono_literals;using chrono::duration_cast;using chrono::milliseconds;using chrono::seconds;using chrono::steady_clock;TestResult *test_connectivity();TestResult *test_connectivity_fail_on_wrong_fingerprint();TestResult *test_pem();TestResult *test_negotiated();TestResult *test_reliability();TestResult *test_turn_connectivity();TestResult *test_track();TestResult *test_capi_connectivity();TestResult *test_capi_track();TestResult *test_websocket();TestResult *test_websocketserver();TestResult *test_capi_websocketserver();size_t benchmark(chrono::milliseconds duration);void test_benchmark() {	size_t goodput = benchmark(10s);	if (goodput == 0)		throw runtime_error("No data received");	const size_t threshold = 1000; // 1 MB/s;	if (goodput < threshold)		throw runtime_error("Goodput is too low");}TestResult *testCppCleanup() {	try {		// Every created object must have been destroyed, otherwise the wait will block		if (rtc::Cleanup().wait_for(10s) == future_status::timeout)			return new TestResult(false, "timeout");		return new TestResult(true);	} catch (const exception &e) {		return new TestResult(false, e.what());	}}TestResult *testCCleanup() {	try {		rtcCleanup();		return new TestResult(true);	} catch (const exception &e) {		return new TestResult(false, e.what());	}}static const auto tests = {    // C++ API tests    new Test("WebRTC connectivity", test_connectivity),    new Test("WebRTC broken fingerprint", test_connectivity_fail_on_wrong_fingerprint),    new Test("pem", test_pem),    // TODO: Temporarily disabled as the Open Relay TURN server is unreliable    // new Test("WebRTC TURN connectivity", test_turn_connectivity),    new Test("WebRTC negotiated DataChannel", test_negotiated),    new Test("WebRTC reliability mode", test_reliability),#if RTC_ENABLE_MEDIA    new Test("WebRTC track", test_track),#endif#if RTC_ENABLE_WEBSOCKET    // TODO: Temporarily disabled as the echo service is unreliable    // new Test("WebSocket", test_websocket),    new Test("WebSocketServer", test_websocketserver),#endif    new Test("WebRTC Cpp API cleanup", testCppCleanup),    // C API tests    new Test("WebRTC C API connectivity", test_capi_connectivity),#if RTC_ENABLE_MEDIA    new Test("WebRTC C API track", test_capi_track),#endif#if RTC_ENABLE_WEBSOCKET    new Test("WebSocketServer C API", test_capi_websocketserver),#endif    new Test("WebRTC C API cleanup", testCCleanup),};int main(int argc, char **argv) {	int success_tests = 0;	int failed_tests = 0;	steady_clock::time_point startTime, endTime;	startTime = steady_clock::now();	for (auto test : tests) {		auto res = test->run();		if (res->success) {			success_tests++;		} else {			failed_tests++;		}	}	endTime = steady_clock::now();	auto durationMs = duration_cast<milliseconds>(endTime - startTime);	auto durationS = duration_cast<seconds>(endTime - startTime);	cout << "Finished " << success_tests + failed_tests << " tests in " << durationS.count()	     << "s (" << durationMs.count() << " ms). Succeeded: " << success_tests	     << ". Failed: " << failed_tests << "." << endl;	/*	    // Benchmark	    try {	        cout << endl << "*** Running WebRTC benchmark..." << endl;	        test_benchmark();	        cout << "*** Finished WebRTC benchmark" << endl;	    } catch (const exception &e) {	        cerr << "WebRTC benchmark failed: " << e.what() << endl;	        std::this_thread::sleep_for(2s);	        return -1;	    }	*/	return 0;}
 |