summaryrefslogtreecommitdiff
path: root/tests/server-tests/white-box/openvpn.rb
blob: adda34a964fc9791a5be0e05ff851a0e05e449f2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
raise SkipTest unless service?(:openvpn)

class OpenVPN < LeapTest
  depends_on "Network"

  def setup
  end

  def test_01_Are_daemons_running?
    assert_running match: '^/usr/sbin/openvpn .* /etc/openvpn/tcp_config.conf$'
    assert_running match: '^/usr/sbin/openvpn .* /etc/openvpn/udp_config.conf$'
    assert_running match: '^/usr/sbin/unbound'
    pass
  end

  def test_02_Can_connect_to_openvpn?
    # because of the way the firewall rules are currently set up, you can only
    # connect to the standard 1194 openvpn port when you are connecting
    # from the same host as openvpn is running on.
    #
    # so, this is disabled for now:
    # $node['openvpn']['ports'].each {|port| ...}
    #

    $node['openvpn']['protocols'].each do |protocol|
      assert_openvpn_is_bound_to_port($node['openvpn']['gateway_address'], protocol, 1194)
    end
    pass
  end

  private

  #
  # asserting succeeds if openvpn appears to be correctly bound and we can
  # connect to it. we don't actually try to establish a vpn connection in this
  # test, we just check to see that it sort of looks like it is openvpn running
  # on the port.
  #
  def assert_openvpn_is_bound_to_port(ip_address, protocol, port)
    protocol = protocol.downcase
    if protocol == 'udp'
      # this sends a magic string to openvpn to attempt to start the protocol.
      nc_output = `/bin/echo -e "\\x38\\x01\\x00\\x00\\x00\\x00\\x00\\x00\\x00" | timeout 0.5 nc -u #{ip_address} #{port}`.strip
      assert !nc_output.empty?, "Could not connect to OpenVPN daemon at #{ip_address} on port #{port} (#{protocol})."
    elsif protocol == 'tcp'
      assert system("openssl s_client -connect #{ip_address}:#{port} 2>&1 | grep -q CONNECTED"),
        "Could not connect to OpenVPN daemon at #{ip_address} on port #{port} (#{protocol})."
    else
      assert false, "invalid openvpn protocol #{protocol}"
    end
  end
end