1
0
mirror of https://github.com/tonarino/innernet.git synced 2025-01-06 03:54:04 +02:00

docker-tests: add simultaneous peer invitation test

This commit is contained in:
Jake McGinty 2021-11-12 17:53:37 +09:00
parent d7c491c8f3
commit e6f25ca1d7
2 changed files with 50 additions and 2 deletions

View File

@ -539,7 +539,8 @@ fn fetch(
log::info!("fetching state from server."); log::info!("fetching state from server.");
let mut store = DataStore::open_or_create(interface)?; let mut store = DataStore::open_or_create(interface)?;
let State { peers, cidrs } = Api::new(&config.server).http("GET", "/user/state")?; let api = Api::new(&config.server);
let State { peers, cidrs } = api.http("GET", "/user/state")?;
let device = Device::get(interface, network.backend)?; let device = Device::get(interface, network.backend)?;
let modifications = device.diff(&peers); let modifications = device.diff(&peers);
@ -581,7 +582,7 @@ fn fetch(
candidates.len(), candidates.len(),
if candidates.len() == 1 { "" } else { "es" } if candidates.len() == 1 { "" } else { "es" }
); );
match Api::new(&config.server).http_form::<_, ()>("PUT", "/user/candidates", &candidates) { match api.http_form::<_, ()>("PUT", "/user/candidates", &candidates) {
Err(ureq::Error::Status(404, _)) => { Err(ureq::Error::Status(404, _)) => {
log::warn!("your network is using an old version of innernet-server that doesn't support NAT traversal candidate reporting.") log::warn!("your network is using an old version of innernet-server that doesn't support NAT traversal candidate reporting.")
}, },

View File

@ -147,6 +147,53 @@ cmd docker cp "$tmp_dir/peer2.toml" "$PEER2_CONTAINER:/app/invite.toml"
cmd docker start "$PEER2_CONTAINER" cmd docker start "$PEER2_CONTAINER"
sleep 10 sleep 10
info "Creating invitation for fourth and fifth peer from first peer."
cmd docker exec "$PEER1_CONTAINER" innernet \
add-peer evilcorp \
--name "peer4" \
--cidr "robots" \
--admin false \
--auto-ip \
--save-config "/app/peer4.toml" \
--invite-expires "30s" \
--yes
cmd docker cp "$PEER1_CONTAINER:/app/peer4.toml" "$tmp_dir"
cmd docker exec "$PEER1_CONTAINER" innernet \
add-peer evilcorp \
--name "peer5" \
--cidr "robots" \
--admin false \
--auto-ip \
--save-config "/app/peer5.toml" \
--invite-expires "30s" \
--yes
cmd docker cp "$PEER1_CONTAINER:/app/peer5.toml" "$tmp_dir"
info "Starting fourth and fifth peer and redeeming simultaneously."
PEER4_CONTAINER=$(docker create --rm -it \
--network "$NETWORK" \
--ip 172.18.1.4 \
--volume /dev/net/tun:/dev/net/tun \
--cap-add NET_ADMIN \
--env INTERFACE=evilcorp \
--env INNERNET_ARGS="$INNERNET_ARGS" \
innernet /app/start-client.sh)
cmd docker cp "$tmp_dir/peer4.toml" "$PEER4_CONTAINER:/app/invite.toml"
PEER5_CONTAINER=$(docker create --rm -it \
--network "$NETWORK" \
--ip 172.18.1.5 \
--volume /dev/net/tun:/dev/net/tun \
--cap-add NET_ADMIN \
--env INTERFACE=evilcorp \
--env INNERNET_ARGS="$INNERNET_ARGS" \
innernet /app/start-client.sh)
cmd docker cp "$tmp_dir/peer5.toml" "$PEER5_CONTAINER:/app/invite.toml"
cmd docker start "$PEER4_CONTAINER"
info "peer4 started as $PEER4_CONTAINER"
cmd docker start -a "$PEER5_CONTAINER" &
info "peer5 started as $PEER5_CONTAINER"
info "Checking connectivity betweeen peers." info "Checking connectivity betweeen peers."
cmd docker exec "$PEER2_CONTAINER" ping -c3 10.66.0.1 cmd docker exec "$PEER2_CONTAINER" ping -c3 10.66.0.1
cmd docker exec "$PEER2_CONTAINER" ping -c3 10.66.1.1 cmd docker exec "$PEER2_CONTAINER" ping -c3 10.66.1.1