| # |
| # Licensed to the Apache Software Foundation (ASF) under one or more |
| # contributor license agreements. See the NOTICE file distributed with |
| # this work for additional information regarding copyright ownership. |
| # The ASF licenses this file to You under the Apache License, Version 2.0 |
| # (the "License"); you may not use this file except in compliance with |
| # the License. You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| # |
| use t::APISIX 'no_plan'; |
| |
| repeat_each(1); |
| no_root_location(); |
| no_shuffle(); |
| |
| add_block_preprocessor(sub { |
| my ($block) = @_; |
| |
| if (!$block->yaml_config) { |
| my $yaml_config = <<_EOC_; |
| apisix: |
| node_listen: 1984 |
| enable_admin: false |
| deployment: |
| role: data_plane |
| role_data_plane: |
| config_provider: yaml |
| discovery: # service discovery center |
| dns: |
| servers: |
| - "127.0.0.1:1053" |
| _EOC_ |
| |
| $block->set_value("yaml_config", $yaml_config); |
| } |
| |
| if ($block->apisix_yaml) { |
| my $upstream = <<_EOC_; |
| stream_routes: |
| - id: 1 |
| server_port: 1985 |
| upstream_id: 1 |
| #END |
| _EOC_ |
| |
| $block->set_value("apisix_yaml", $block->apisix_yaml . $upstream); |
| } |
| |
| if (!$block->stream_request) { |
| $block->set_value("stream_request", "GET /hello HTTP/1.0\r\nHost: 127.0.0.1:1985\r\n\r\n"); |
| } |
| |
| }); |
| |
| run_tests(); |
| |
| __DATA__ |
| |
| === TEST 1: default port to 53 |
| --- log_level: debug |
| --- yaml_config |
| apisix: |
| node_listen: 1984 |
| enable_admin: false |
| deployment: |
| role: data_plane |
| role_data_plane: |
| config_provider: yaml |
| discovery: # service discovery center |
| dns: |
| servers: |
| - "127.0.0.1" |
| --- apisix_yaml |
| upstreams: |
| - service_name: sd.test.local |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- error_log |
| connect to 127.0.0.1:53 |
| |
| |
| |
| === TEST 2: A |
| --- apisix_yaml |
| upstreams: |
| - service_name: "sd.test.local:1980" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- grep_error_log eval |
| qr/upstream nodes: \{[^}]+\}/ |
| --- grep_error_log_out eval |
| qr/upstream nodes: \{("127.0.0.1:1980":1,"127.0.0.2:1980":1|"127.0.0.2:1980":1,"127.0.0.1:1980":1)\}/ |
| --- stream_response_like |
| hello world |
| |
| |
| |
| === TEST 3: AAAA |
| --- listen_ipv6 |
| --- apisix_yaml |
| upstreams: |
| - service_name: "ipv6.sd.test.local:1980" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- stream_response_like |
| hello world |
| --- grep_error_log eval |
| qr/proxy request to \S+/ |
| --- grep_error_log_out |
| proxy request to [0:0:0:0:0:0:0:1]:1980 |
| |
| |
| |
| === TEST 4: prefer A to AAAA |
| --- listen_ipv6 |
| --- apisix_yaml |
| upstreams: |
| - service_name: "mix.sd.test.local:1980" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- stream_response_like |
| hello world |
| --- grep_error_log eval |
| qr/proxy request to \S+/ |
| --- grep_error_log_out |
| proxy request to 127.0.0.1:1980 |
| |
| |
| |
| === TEST 5: no /etc/hosts |
| --- apisix_yaml |
| upstreams: |
| - service_name: test.com |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- error_log |
| failed to query the DNS server |
| |
| |
| |
| === TEST 6: no /etc/resolv.conf |
| --- yaml_config |
| apisix: |
| node_listen: 1984 |
| enable_admin: false |
| enable_resolv_search_option: false |
| deployment: |
| role: data_plane |
| role_data_plane: |
| config_provider: yaml |
| discovery: # service discovery center |
| dns: |
| servers: |
| - "127.0.0.1:1053" |
| --- apisix_yaml |
| upstreams: |
| - service_name: apisix |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- error_log |
| failed to query the DNS server |
| |
| |
| |
| === TEST 7: SRV |
| --- apisix_yaml |
| upstreams: |
| - service_name: "srv.test.local" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- grep_error_log eval |
| qr/upstream nodes: \{[^}]+\}/ |
| --- grep_error_log_out eval |
| qr/upstream nodes: \{("127.0.0.1:1980":60,"127.0.0.2:1980":20|"127.0.0.2:1980":20,"127.0.0.1:1980":60)\}/ |
| --- stream_response_like |
| hello world |
| |
| |
| |
| === TEST 8: SRV (RFC 2782 style) |
| --- apisix_yaml |
| upstreams: |
| - service_name: "_sip._tcp.srv.test.local" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- grep_error_log eval |
| qr/upstream nodes: \{[^}]+\}/ |
| --- grep_error_log_out eval |
| qr/upstream nodes: \{("127.0.0.1:1980":60,"127.0.0.2:1980":20|"127.0.0.2:1980":20,"127.0.0.1:1980":60)\}/ |
| --- stream_response_like |
| hello world |
| |
| |
| |
| === TEST 9: SRV (different port) |
| --- apisix_yaml |
| upstreams: |
| - service_name: "port.srv.test.local" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- grep_error_log eval |
| qr/upstream nodes: \{[^}]+\}/ |
| --- grep_error_log_out eval |
| qr/upstream nodes: \{("127.0.0.1:1980":60,"127.0.0.2:1981":20|"127.0.0.2:1981":20,"127.0.0.1:1980":60)\}/ |
| --- stream_response_like |
| hello world |
| |
| |
| |
| === TEST 10: SRV (zero weight) |
| --- apisix_yaml |
| upstreams: |
| - service_name: "zero-weight.srv.test.local" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- grep_error_log eval |
| qr/upstream nodes: \{[^}]+\}/ |
| --- grep_error_log_out eval |
| qr/upstream nodes: \{("127.0.0.1:1980":60,"127.0.0.2:1980":1|"127.0.0.2:1980":1,"127.0.0.1:1980":60)\}/ |
| --- stream_response_like |
| hello world |
| |
| |
| |
| === TEST 11: SRV (split weight) |
| --- apisix_yaml |
| upstreams: |
| - service_name: "split-weight.srv.test.local" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- grep_error_log eval |
| qr/upstream nodes: \{[^}]+\}/ |
| --- grep_error_log_out eval |
| qr/upstream nodes: \{(,?"127.0.0.(1:1980":200|3:1980":1|4:1980":1)){3}\}/ |
| --- stream_response_like |
| hello world |
| |
| |
| |
| === TEST 12: SRV (priority) |
| --- apisix_yaml |
| upstreams: |
| - service_name: "priority.srv.test.local" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- stream_response_like |
| hello world |
| --- error_log |
| connect() failed |
| --- grep_error_log eval |
| qr/proxy request to \S+/ |
| --- grep_error_log_out |
| proxy request to 127.0.0.1:1979 |
| proxy request to 127.0.0.2:1980 |
| |
| |
| |
| === TEST 13: prefer SRV than A |
| --- apisix_yaml |
| upstreams: |
| - service_name: "srv-a.test.local" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- error_log |
| proxy request to 127.0.0.1:1980 |
| --- stream_response_like |
| hello world |
| |
| |
| |
| === TEST 14: SRV (port is 0) |
| --- apisix_yaml |
| upstreams: |
| - service_name: "zero.srv.test.local" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- error_log |
| no valid upstream node |
| |
| |
| |
| === TEST 15: SRV (override port) |
| --- apisix_yaml |
| upstreams: |
| - service_name: "port.srv.test.local:1980" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- grep_error_log eval |
| qr/upstream nodes: \{[^}]+\}/ |
| --- grep_error_log_out eval |
| qr/upstream nodes: \{("127.0.0.1:1980":60,"127.0.0.2:1980":20|"127.0.0.2:1980":20,"127.0.0.1:1980":60)\}/ |
| --- stream_response_like |
| hello world |
| |
| |
| |
| === TEST 16: prefer A than SRV when A is ahead of SRV in config.yaml |
| --- yaml_config |
| apisix: |
| node_listen: 1984 |
| enable_admin: false |
| deployment: |
| role: data_plane |
| role_data_plane: |
| config_provider: yaml |
| discovery: |
| dns: |
| servers: |
| - "127.0.0.1:1053" |
| order: |
| - A |
| - SRV |
| --- apisix_yaml |
| upstreams: |
| - service_name: "srv-a.test.local" |
| discovery_type: dns |
| type: roundrobin |
| id: 1 |
| --- error_log |
| no valid upstream node |