Add Tor feature flag and only run test if enabled

This commit is contained in:
Philipp Hoenisch 2020-10-20 14:33:32 +11:00
parent 5e19949d71
commit 295216a8ee
No known key found for this signature in database
GPG Key ID: E5F8E74C672BC666
4 changed files with 77 additions and 64 deletions

View File

@ -46,6 +46,9 @@ jobs:
build_test:
runs-on: ubuntu-latest
steps:
- name: Install tor
run: sudo apt-get tor
- name: Checkout sources
uses: actions/checkout@v2

View File

@ -22,7 +22,7 @@ serde_json = "1"
sha2 = "0.9"
thiserror = "1"
tokio = { version = "0.2", default-features = false, features = ["blocking", "macros", "rt-core", "time", "rt-threaded"] }
torut = "0.1"
torut = { version = "0.1", optional = true }
tracing = "0.1"
[dev-dependencies]
@ -35,3 +35,7 @@ spectral = "0.6"
testcontainers = "0.10"
tracing = "0.1"
tracing-subscriber = "0.2"
[features]
default = []
tor = ["torut"]

View File

@ -49,5 +49,6 @@ pub mod alice;
pub mod bitcoin;
pub mod bob;
pub mod monero;
#[cfg(feature = "tor")]
pub mod tor;
pub mod transport;

View File

@ -1,20 +1,24 @@
use anyhow::Result;
use hyper::service::{make_service_fn, service_fn};
use reqwest::StatusCode;
use spectral::prelude::*;
use std::convert::Infallible;
use tokio::sync::oneshot::Receiver;
use torut::onion::TorSecretKeyV3;
use xmr_btc::tor::{AuthenticatedConnection, TOR_PROXY_ADDR};
#[cfg(feature = "tor")]
mod tor_test {
async fn hello_world(
use anyhow::Result;
use hyper::service::{make_service_fn, service_fn};
use reqwest::StatusCode;
use spectral::prelude::*;
use std::convert::Infallible;
use tokio::sync::oneshot::Receiver;
use torut::onion::TorSecretKeyV3;
use xmr_btc::tor::{AuthenticatedConnection, TOR_PROXY_ADDR};
async fn hello_world(
_req: hyper::Request<hyper::Body>,
) -> Result<hyper::Response<hyper::Body>, Infallible> {
) -> Result<hyper::Response<hyper::Body>, Infallible> {
Ok(hyper::Response::new("Hello World".into()))
}
}
fn start_test_service(port: u16, rx: Receiver<()>) {
let make_svc = make_service_fn(|_conn| async { Ok::<_, Infallible>(service_fn(hello_world)) });
fn start_test_service(port: u16, rx: Receiver<()>) {
let make_svc =
make_service_fn(|_conn| async { Ok::<_, Infallible>(service_fn(hello_world)) });
let addr = ([127, 0, 0, 1], port).into();
let server = hyper::Server::bind(&addr).serve(make_svc);
let graceful = server.with_graceful_shutdown(async {
@ -26,10 +30,10 @@ fn start_test_service(port: u16, rx: Receiver<()>) {
eprintln!("server error: {}", e);
}
});
}
}
#[tokio::test]
async fn test_tor_control_port() -> Result<()> {
#[tokio::test]
async fn test_tor_control_port() -> Result<()> {
// Setup test HTTP Server
let (tx, rx) = tokio::sync::oneshot::channel::<()>();
let port = 8080;
@ -61,4 +65,5 @@ async fn test_tor_control_port() -> Result<()> {
// gracefully shut down server
let _ = tx.send(());
Ok(())
}
}