From e0b09f8e76fe026038874e78f4061caddbaf1535 Mon Sep 17 00:00:00 2001 From: Andreas Steffen Date: Tue, 16 Jun 2009 18:47:28 +0200 Subject: [PATCH] added two gcrypt scenarios --- .../gcrypt/rw-cert-ikev1/description.txt | 12 +++++++++ .../tests/gcrypt/rw-cert-ikev1/evaltest.dat | 10 ++++++++ .../rw-cert-ikev1/hosts/carol/etc/ipsec.conf | 25 +++++++++++++++++++ .../hosts/carol/etc/strongswan.conf | 14 +++++++++++ .../rw-cert-ikev1/hosts/dave/etc/ipsec.conf | 25 +++++++++++++++++++ .../hosts/dave/etc/strongswan.conf | 15 +++++++++++ .../rw-cert-ikev1/hosts/moon/etc/ipsec.conf | 24 ++++++++++++++++++ .../hosts/moon/etc/strongswan.conf | 14 +++++++++++ .../tests/gcrypt/rw-cert-ikev1/posttest.dat | 6 +++++ .../tests/gcrypt/rw-cert-ikev1/pretest.dat | 9 +++++++ testing/tests/gcrypt/rw-cert-ikev1/test.conf | 21 ++++++++++++++++ .../gcrypt/rw-cert-ikev2/description.txt | 12 +++++++++ .../tests/gcrypt/rw-cert-ikev2/evaltest.dat | 10 ++++++++ .../rw-cert-ikev2/hosts/carol/etc/ipsec.conf | 24 ++++++++++++++++++ .../hosts/carol/etc/strongswan.conf | 11 ++++++++ .../rw-cert-ikev2/hosts/dave/etc/ipsec.conf | 24 ++++++++++++++++++ .../hosts/dave/etc/strongswan.conf | 12 +++++++++ .../rw-cert-ikev2/hosts/moon/etc/ipsec.conf | 23 +++++++++++++++++ .../hosts/moon/etc/strongswan.conf | 11 ++++++++ .../tests/gcrypt/rw-cert-ikev2/posttest.dat | 6 +++++ .../tests/gcrypt/rw-cert-ikev2/pretest.dat | 9 +++++++ testing/tests/gcrypt/rw-cert-ikev2/test.conf | 21 ++++++++++++++++ 22 files changed, 338 insertions(+) create mode 100644 testing/tests/gcrypt/rw-cert-ikev1/description.txt create mode 100644 testing/tests/gcrypt/rw-cert-ikev1/evaltest.dat create mode 100755 testing/tests/gcrypt/rw-cert-ikev1/hosts/carol/etc/ipsec.conf create mode 100644 testing/tests/gcrypt/rw-cert-ikev1/hosts/carol/etc/strongswan.conf create mode 100755 testing/tests/gcrypt/rw-cert-ikev1/hosts/dave/etc/ipsec.conf create mode 100644 testing/tests/gcrypt/rw-cert-ikev1/hosts/dave/etc/strongswan.conf create mode 100755 testing/tests/gcrypt/rw-cert-ikev1/hosts/moon/etc/ipsec.conf create mode 100644 testing/tests/gcrypt/rw-cert-ikev1/hosts/moon/etc/strongswan.conf create mode 100644 testing/tests/gcrypt/rw-cert-ikev1/posttest.dat create mode 100644 testing/tests/gcrypt/rw-cert-ikev1/pretest.dat create mode 100644 testing/tests/gcrypt/rw-cert-ikev1/test.conf create mode 100644 testing/tests/gcrypt/rw-cert-ikev2/description.txt create mode 100644 testing/tests/gcrypt/rw-cert-ikev2/evaltest.dat create mode 100755 testing/tests/gcrypt/rw-cert-ikev2/hosts/carol/etc/ipsec.conf create mode 100644 testing/tests/gcrypt/rw-cert-ikev2/hosts/carol/etc/strongswan.conf create mode 100755 testing/tests/gcrypt/rw-cert-ikev2/hosts/dave/etc/ipsec.conf create mode 100644 testing/tests/gcrypt/rw-cert-ikev2/hosts/dave/etc/strongswan.conf create mode 100755 testing/tests/gcrypt/rw-cert-ikev2/hosts/moon/etc/ipsec.conf create mode 100644 testing/tests/gcrypt/rw-cert-ikev2/hosts/moon/etc/strongswan.conf create mode 100644 testing/tests/gcrypt/rw-cert-ikev2/posttest.dat create mode 100644 testing/tests/gcrypt/rw-cert-ikev2/pretest.dat create mode 100644 testing/tests/gcrypt/rw-cert-ikev2/test.conf diff --git a/testing/tests/gcrypt/rw-cert-ikev1/description.txt b/testing/tests/gcrypt/rw-cert-ikev1/description.txt new file mode 100644 index 000000000..f60f5b1ad --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/description.txt @@ -0,0 +1,12 @@ +The roadwarrior carol and the gateway moon use the gcrypt +plugin based on the GNU Libgcrypt library for all cryptographical functions +whereas roadwarrior dave uses the default strongSwan cryptographical +plugins aes des sha1 sha2 md5 gmp. +

+The roadwarriors carol and dave set up a connection each +to gateway moon. The authentication is based on X.509 certificates. +Upon the successful establishment of the IPsec tunnels, leftfirewall=yes +automatically inserts iptables-based firewall rules that let pass the tunneled traffic. +In order to test both tunnel and firewall, both carol and dave ping +the client alice behind the gateway moon. + diff --git a/testing/tests/gcrypt/rw-cert-ikev1/evaltest.dat b/testing/tests/gcrypt/rw-cert-ikev1/evaltest.dat new file mode 100644 index 000000000..1a9b9159f --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/evaltest.dat @@ -0,0 +1,10 @@ +moon::ipsec statusall::IPsec SA established::YES +carol::ipsec statusall::IPsec SA established::YES +dave::ipsec statusall::IPsec SA established::YES +carol::ping -c 1 PH_IP_ALICE::64 bytes from PH_IP_ALICE: icmp_seq=1::YES +dave::ping -c 1 PH_IP_ALICE::64 bytes from PH_IP_ALICE: icmp_seq=1::YES +moon::tcpdump::IP carol.strongswan.org > moon.strongswan.org: ESP::YES +moon::tcpdump::IP moon.strongswan.org > carol.strongswan.org: ESP::YES +moon::tcpdump::IP dave.strongswan.org > moon.strongswan.org: ESP::YES +moon::tcpdump::IP moon.strongswan.org > dave.strongswan.org: ESP::YES + diff --git a/testing/tests/gcrypt/rw-cert-ikev1/hosts/carol/etc/ipsec.conf b/testing/tests/gcrypt/rw-cert-ikev1/hosts/carol/etc/ipsec.conf new file mode 100755 index 000000000..80dae3719 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/hosts/carol/etc/ipsec.conf @@ -0,0 +1,25 @@ +# /etc/ipsec.conf - strongSwan IPsec configuration file + +config setup + crlcheckinterval=180 + strictcrlpolicy=no + charonstart=no + plutodebug=control + +conn %default + ikelifetime=60m + keylife=20m + rekeymargin=3m + keyingtries=1 + keyexchange=ikev1 + ike=3des-sha1-modp1536! + +conn home + left=PH_IP_CAROL + leftcert=carolCert.pem + leftid=carol@strongswan.org + leftfirewall=yes + right=PH_IP_MOON + rightid=@moon.strongswan.org + rightsubnet=10.1.0.0/16 + auto=add diff --git a/testing/tests/gcrypt/rw-cert-ikev1/hosts/carol/etc/strongswan.conf b/testing/tests/gcrypt/rw-cert-ikev1/hosts/carol/etc/strongswan.conf new file mode 100644 index 000000000..0840260c3 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/hosts/carol/etc/strongswan.conf @@ -0,0 +1,14 @@ +# /etc/strongswan.conf - strongSwan configuration file + +pluto { + load = test-vectors gcrypt pubkey hmac curl +} + +# pluto uses optimized DH exponent sizes (RFC 3526) + +libstrongswan { + dh_exponent_ansi_x9_42 = no + crypto_test { + on_add = yes + } +} diff --git a/testing/tests/gcrypt/rw-cert-ikev1/hosts/dave/etc/ipsec.conf b/testing/tests/gcrypt/rw-cert-ikev1/hosts/dave/etc/ipsec.conf new file mode 100755 index 000000000..73167caad --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/hosts/dave/etc/ipsec.conf @@ -0,0 +1,25 @@ +# /etc/ipsec.conf - strongSwan IPsec configuration file + +config setup + crlcheckinterval=180 + strictcrlpolicy=no + charonstart=no + plutodebug=control + +conn %default + ikelifetime=60m + keylife=20m + rekeymargin=3m + keyingtries=1 + keyexchange=ikev1 + ike=aes256-sha256-modp2048! + +conn home + left=PH_IP_DAVE + leftcert=daveCert.pem + leftid=dave@strongswan.org + leftfirewall=yes + right=PH_IP_MOON + rightid=@moon.strongswan.org + rightsubnet=10.1.0.0/16 + auto=add diff --git a/testing/tests/gcrypt/rw-cert-ikev1/hosts/dave/etc/strongswan.conf b/testing/tests/gcrypt/rw-cert-ikev1/hosts/dave/etc/strongswan.conf new file mode 100644 index 000000000..fdfb0003f --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/hosts/dave/etc/strongswan.conf @@ -0,0 +1,15 @@ +# /etc/strongswan.conf - strongSwan configuration file + +pluto { + load = test-vectors aes des sha1 sha2 md5 gmp pubkey random hmac curl +} + +# pluto uses optimized DH exponent sizes (RFC 3526) + +libstrongswan { + dh_exponent_ansi_x9_42 = no + crypto_test { + required = yes + on_add = yes + } +} diff --git a/testing/tests/gcrypt/rw-cert-ikev1/hosts/moon/etc/ipsec.conf b/testing/tests/gcrypt/rw-cert-ikev1/hosts/moon/etc/ipsec.conf new file mode 100755 index 000000000..f365b07da --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/hosts/moon/etc/ipsec.conf @@ -0,0 +1,24 @@ +# /etc/ipsec.conf - strongSwan IPsec configuration file + +config setup + crlcheckinterval=180 + strictcrlpolicy=no + charonstart=no + plutodebug=control + +conn %default + ikelifetime=60m + keylife=20m + rekeymargin=3m + keyingtries=1 + keyexchange=ikev1 + ike=aes256-sha256-modp2048,3des-sha1-modp1536! + +conn rw + left=PH_IP_MOON + leftcert=moonCert.pem + leftid=@moon.strongswan.org + leftsubnet=10.1.0.0/16 + leftfirewall=yes + right=%any + auto=add diff --git a/testing/tests/gcrypt/rw-cert-ikev1/hosts/moon/etc/strongswan.conf b/testing/tests/gcrypt/rw-cert-ikev1/hosts/moon/etc/strongswan.conf new file mode 100644 index 000000000..0840260c3 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/hosts/moon/etc/strongswan.conf @@ -0,0 +1,14 @@ +# /etc/strongswan.conf - strongSwan configuration file + +pluto { + load = test-vectors gcrypt pubkey hmac curl +} + +# pluto uses optimized DH exponent sizes (RFC 3526) + +libstrongswan { + dh_exponent_ansi_x9_42 = no + crypto_test { + on_add = yes + } +} diff --git a/testing/tests/gcrypt/rw-cert-ikev1/posttest.dat b/testing/tests/gcrypt/rw-cert-ikev1/posttest.dat new file mode 100644 index 000000000..7cebd7f25 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/posttest.dat @@ -0,0 +1,6 @@ +moon::ipsec stop +carol::ipsec stop +dave::ipsec stop +moon::/etc/init.d/iptables stop 2> /dev/null +carol::/etc/init.d/iptables stop 2> /dev/null +dave::/etc/init.d/iptables stop 2> /dev/null diff --git a/testing/tests/gcrypt/rw-cert-ikev1/pretest.dat b/testing/tests/gcrypt/rw-cert-ikev1/pretest.dat new file mode 100644 index 000000000..42e9d7c24 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/pretest.dat @@ -0,0 +1,9 @@ +moon::/etc/init.d/iptables start 2> /dev/null +carol::/etc/init.d/iptables start 2> /dev/null +dave::/etc/init.d/iptables start 2> /dev/null +moon::ipsec start +carol::ipsec start +dave::ipsec start +carol::sleep 1 +carol::ipsec up home +dave::ipsec up home diff --git a/testing/tests/gcrypt/rw-cert-ikev1/test.conf b/testing/tests/gcrypt/rw-cert-ikev1/test.conf new file mode 100644 index 000000000..70416826e --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev1/test.conf @@ -0,0 +1,21 @@ +#!/bin/bash +# +# This configuration file provides information on the +# UML instances used for this test + +# All UML instances that are required for this test +# +UMLHOSTS="alice moon carol winnetou dave" + +# Corresponding block diagram +# +DIAGRAM="a-m-c-w-d.png" + +# UML instances on which tcpdump is to be started +# +TCPDUMPHOSTS="moon" + +# UML instances on which IPsec is started +# Used for IPsec logging purposes +# +IPSECHOSTS="moon carol dave" diff --git a/testing/tests/gcrypt/rw-cert-ikev2/description.txt b/testing/tests/gcrypt/rw-cert-ikev2/description.txt new file mode 100644 index 000000000..f60f5b1ad --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/description.txt @@ -0,0 +1,12 @@ +The roadwarrior carol and the gateway moon use the gcrypt +plugin based on the GNU Libgcrypt library for all cryptographical functions +whereas roadwarrior dave uses the default strongSwan cryptographical +plugins aes des sha1 sha2 md5 gmp. +

+The roadwarriors carol and dave set up a connection each +to gateway moon. The authentication is based on X.509 certificates. +Upon the successful establishment of the IPsec tunnels, leftfirewall=yes +automatically inserts iptables-based firewall rules that let pass the tunneled traffic. +In order to test both tunnel and firewall, both carol and dave ping +the client alice behind the gateway moon. + diff --git a/testing/tests/gcrypt/rw-cert-ikev2/evaltest.dat b/testing/tests/gcrypt/rw-cert-ikev2/evaltest.dat new file mode 100644 index 000000000..06a0f8cda --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/evaltest.dat @@ -0,0 +1,10 @@ +moon::ipsec statusall::rw.*ESTABLISHED::YES +carol::ipsec statusall::home.*ESTABLISHED::YES +dave::ipsec statusall::home.*ESTABLISHED::YES +carol::ping -c 1 PH_IP_ALICE::64 bytes from PH_IP_ALICE: icmp_seq=1::YES +dave::ping -c 1 PH_IP_ALICE::64 bytes from PH_IP_ALICE: icmp_seq=1::YES +moon::tcpdump::IP carol.strongswan.org > moon.strongswan.org: ESP::YES +moon::tcpdump::IP moon.strongswan.org > carol.strongswan.org: ESP::YES +moon::tcpdump::IP dave.strongswan.org > moon.strongswan.org: ESP::YES +moon::tcpdump::IP moon.strongswan.org > dave.strongswan.org: ESP::YES + diff --git a/testing/tests/gcrypt/rw-cert-ikev2/hosts/carol/etc/ipsec.conf b/testing/tests/gcrypt/rw-cert-ikev2/hosts/carol/etc/ipsec.conf new file mode 100755 index 000000000..4a8baa3ae --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/hosts/carol/etc/ipsec.conf @@ -0,0 +1,24 @@ +# /etc/ipsec.conf - strongSwan IPsec configuration file + +config setup + crlcheckinterval=180 + strictcrlpolicy=no + plutostart=no + +conn %default + ikelifetime=60m + keylife=20m + rekeymargin=3m + keyingtries=1 + keyexchange=ikev2 + ike=3des-sha1-modp1536! + +conn home + left=PH_IP_CAROL + leftcert=carolCert.pem + leftid=carol@strongswan.org + leftfirewall=yes + right=PH_IP_MOON + rightid=@moon.strongswan.org + rightsubnet=10.1.0.0/16 + auto=add diff --git a/testing/tests/gcrypt/rw-cert-ikev2/hosts/carol/etc/strongswan.conf b/testing/tests/gcrypt/rw-cert-ikev2/hosts/carol/etc/strongswan.conf new file mode 100644 index 000000000..edb7e40d1 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/hosts/carol/etc/strongswan.conf @@ -0,0 +1,11 @@ +# /etc/strongswan.conf - strongSwan configuration file + +charon { + load = curl test-vectors gcrypt x509 pubkey hmac stroke kernel-netlink updown +} + +libstrongswan { + crypto_test { + on_add = yes + } +} diff --git a/testing/tests/gcrypt/rw-cert-ikev2/hosts/dave/etc/ipsec.conf b/testing/tests/gcrypt/rw-cert-ikev2/hosts/dave/etc/ipsec.conf new file mode 100755 index 000000000..42f03aab3 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/hosts/dave/etc/ipsec.conf @@ -0,0 +1,24 @@ +# /etc/ipsec.conf - strongSwan IPsec configuration file + +config setup + crlcheckinterval=180 + strictcrlpolicy=no + plutostart=no + +conn %default + ikelifetime=60m + keylife=20m + rekeymargin=3m + keyingtries=1 + keyexchange=ikev2 + ike=aes256-sha256-modp2048! + +conn home + left=PH_IP_DAVE + leftcert=daveCert.pem + leftid=dave@strongswan.org + leftfirewall=yes + right=PH_IP_MOON + rightid=@moon.strongswan.org + rightsubnet=10.1.0.0/16 + auto=add diff --git a/testing/tests/gcrypt/rw-cert-ikev2/hosts/dave/etc/strongswan.conf b/testing/tests/gcrypt/rw-cert-ikev2/hosts/dave/etc/strongswan.conf new file mode 100644 index 000000000..f4b6dfdb9 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/hosts/dave/etc/strongswan.conf @@ -0,0 +1,12 @@ +# /etc/strongswan.conf - strongSwan configuration file + +charon { + load = curl test-vectors aes des sha1 sha2 md5 gmp random x509 pubkey hmac stroke kernel-netlink updown +} + +libstrongswan { + crypto_test { + required = yes + on_add = yes + } +} diff --git a/testing/tests/gcrypt/rw-cert-ikev2/hosts/moon/etc/ipsec.conf b/testing/tests/gcrypt/rw-cert-ikev2/hosts/moon/etc/ipsec.conf new file mode 100755 index 000000000..2e84f2e6a --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/hosts/moon/etc/ipsec.conf @@ -0,0 +1,23 @@ +# /etc/ipsec.conf - strongSwan IPsec configuration file + +config setup + crlcheckinterval=180 + strictcrlpolicy=no + plutostart=no + +conn %default + ikelifetime=60m + keylife=20m + rekeymargin=3m + keyingtries=1 + keyexchange=ikev2 + ike=aes256-sha256-modp2048,3des-sha1-modp1536! + +conn rw + left=PH_IP_MOON + leftcert=moonCert.pem + leftid=@moon.strongswan.org + leftsubnet=10.1.0.0/16 + leftfirewall=yes + right=%any + auto=add diff --git a/testing/tests/gcrypt/rw-cert-ikev2/hosts/moon/etc/strongswan.conf b/testing/tests/gcrypt/rw-cert-ikev2/hosts/moon/etc/strongswan.conf new file mode 100644 index 000000000..edb7e40d1 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/hosts/moon/etc/strongswan.conf @@ -0,0 +1,11 @@ +# /etc/strongswan.conf - strongSwan configuration file + +charon { + load = curl test-vectors gcrypt x509 pubkey hmac stroke kernel-netlink updown +} + +libstrongswan { + crypto_test { + on_add = yes + } +} diff --git a/testing/tests/gcrypt/rw-cert-ikev2/posttest.dat b/testing/tests/gcrypt/rw-cert-ikev2/posttest.dat new file mode 100644 index 000000000..7cebd7f25 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/posttest.dat @@ -0,0 +1,6 @@ +moon::ipsec stop +carol::ipsec stop +dave::ipsec stop +moon::/etc/init.d/iptables stop 2> /dev/null +carol::/etc/init.d/iptables stop 2> /dev/null +dave::/etc/init.d/iptables stop 2> /dev/null diff --git a/testing/tests/gcrypt/rw-cert-ikev2/pretest.dat b/testing/tests/gcrypt/rw-cert-ikev2/pretest.dat new file mode 100644 index 000000000..42e9d7c24 --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/pretest.dat @@ -0,0 +1,9 @@ +moon::/etc/init.d/iptables start 2> /dev/null +carol::/etc/init.d/iptables start 2> /dev/null +dave::/etc/init.d/iptables start 2> /dev/null +moon::ipsec start +carol::ipsec start +dave::ipsec start +carol::sleep 1 +carol::ipsec up home +dave::ipsec up home diff --git a/testing/tests/gcrypt/rw-cert-ikev2/test.conf b/testing/tests/gcrypt/rw-cert-ikev2/test.conf new file mode 100644 index 000000000..70416826e --- /dev/null +++ b/testing/tests/gcrypt/rw-cert-ikev2/test.conf @@ -0,0 +1,21 @@ +#!/bin/bash +# +# This configuration file provides information on the +# UML instances used for this test + +# All UML instances that are required for this test +# +UMLHOSTS="alice moon carol winnetou dave" + +# Corresponding block diagram +# +DIAGRAM="a-m-c-w-d.png" + +# UML instances on which tcpdump is to be started +# +TCPDUMPHOSTS="moon" + +# UML instances on which IPsec is started +# Used for IPsec logging purposes +# +IPSECHOSTS="moon carol dave"