summaryrefslogtreecommitdiff
path: root/tests/integration/targets/vyos_ospfv2/tests/cli/rtt.yaml
blob: 7efc2a7b8de361bd560e1d3dd401239ca0b0b7a4 (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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
---
- debug:
    msg: START vyos_ospfv2 round trip integration tests on connection={{
      ansible_connection }}

- include_tasks: _remove_config.yaml

- block:

    - name: Apply the provided configuration (base config)
      register: base_config
      vyos.vyos.vyos_ospfv2:
        config:
          log_adjacency_changes: 'detail'
          max_metric:
            router_lsa:
              administrative: true
              on_shutdown: 10
              on_startup: 10
          default_information:
            originate:
              always: true
              metric: 10
              metric_type: 2
              route_map: 'ingress'
          mpls_te:
            enabled: true
            router_address: '192.0.11.11'
          auto_cost:
            reference_bandwidth: 2
          neighbor:
            - neighbor_id: '192.0.11.12'
              poll_interval: 10
              priority: 2
          redistribute:
            - route_type: 'bgp'
              metric: 10
              metric_type: 2
          passive_interface:
            - 'eth1'
            - 'eth2'
          parameters:
            router_id: '192.0.1.1'
            opaque_lsa: true
            rfc1583_compatibility: true
            abr_type: 'cisco'
          areas:
            - area_id: '2'
              area_type:
                normal: true
              authentication: "plaintext-password"
              shortcut: 'enable'
            - area_id: '3'
              area_type:
                nssa:
                  set: true
            - area_id: '4'
              area_type:
                stub:
                  default_cost: 20
              network:
                - address: '192.0.2.0/24'
              range:
                - address: '192.0.3.0/24'
                  cost: 10
                - address: '192.0.4.0/24'
                  cost: 12
        state: merged

    - name: Gather ospfv2 facts
      vyos.vyos.vyos_facts:
        gather_subset:
          - default
        gather_network_resources:
          - ospfv2

    - name: Apply the provided configuration (config to be reverted)
      register: result
      vyos.vyos.vyos_ospfv2:
        config:
          areas:
            - area_id: '2'
              area_type:
                normal: true
              authentication: "plaintext-password"
              shortcut: 'enable'
            - area_id: '4'
              area_type:
                stub:
                  default_cost: 20
                  set: true
              network:
                - address: '192.0.12.0/24'
                - address: '192.0.2.0/24'
                - address: '192.0.22.0/24'
                - address: '192.0.32.0/24'
              range:
                - address: '1.1.2.0/24'
                  cost: 10
          auto_cost:
            reference_bandwidth: 2
          default_information:
            originate:
              always: true
              metric: 10
              metric_type: 2
              route_map: 'ingress'
          log_adjacency_changes: 'detail'
          max_metric:
            router_lsa:
              administrative: true
              on_shutdown: 10
              on_startup: 10
          mpls_te:
            enabled: true
            router_address: '192.0.22.22'
          neighbor:
            - neighbor_id: '192.0.11.12'
              poll_interval: 10
              priority: 2
          parameters:
            abr_type: 'cisco'
            opaque_lsa: true
            rfc1583_compatibility: true
            router_id: '192.0.1.1'
          passive_interface:
            - 'eth1'
          redistribute:
            - metric: 10
              metric_type: 2
              route_type: 'bgp'
        state: replaced

    - name: Assert that changes were applied
      assert:
        that: "{{ round_trip['after'] == result['after'] }}"

    - name: Revert back to base config using facts round trip
      register: revert
      vyos.vyos.vyos_ospfv2:
        config: "{{ ansible_facts['network_resources']['ospfv2'] }}"
        state: replaced

    - name: Assert that config was reverted
      assert:
        that: "{{ base_config['after'] == revert['after']}}"
  always:

    - include_tasks: _remove_config.yaml