2020-09-08 13:53:25 +01:00
|
|
|
// +build !race
|
|
|
|
|
2020-11-16 12:52:05 +00:00
|
|
|
// TODO(e.burkov): remove this weird buildtag.
|
|
|
|
|
2019-12-11 09:38:58 +00:00
|
|
|
package home
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2019-12-20 11:50:54 +00:00
|
|
|
"encoding/base64"
|
2019-12-11 09:38:58 +00:00
|
|
|
"io/ioutil"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2019-12-20 11:50:54 +00:00
|
|
|
"github.com/AdguardTeam/dnsproxy/proxyutil"
|
2019-12-11 09:38:58 +00:00
|
|
|
"github.com/AdguardTeam/dnsproxy/upstream"
|
2019-12-20 11:50:54 +00:00
|
|
|
"github.com/miekg/dns"
|
2019-12-11 09:38:58 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
const yamlConf = `bind_host: 127.0.0.1
|
|
|
|
bind_port: 3000
|
|
|
|
users: []
|
|
|
|
language: en
|
|
|
|
rlimit_nofile: 0
|
|
|
|
web_session_ttl: 720
|
|
|
|
dns:
|
|
|
|
bind_host: 127.0.0.1
|
|
|
|
port: 5354
|
|
|
|
statistics_interval: 90
|
|
|
|
querylog_enabled: true
|
|
|
|
querylog_interval: 90
|
2020-03-19 12:53:25 +00:00
|
|
|
querylog_size_memory: 0
|
2019-12-11 09:38:58 +00:00
|
|
|
protection_enabled: true
|
|
|
|
blocking_mode: null_ip
|
|
|
|
blocked_response_ttl: 0
|
|
|
|
ratelimit: 100
|
|
|
|
ratelimit_whitelist: []
|
|
|
|
refuse_any: false
|
|
|
|
bootstrap_dns:
|
|
|
|
- 1.1.1.1:53
|
|
|
|
all_servers: false
|
|
|
|
allowed_clients: []
|
|
|
|
disallowed_clients: []
|
|
|
|
blocked_hosts: []
|
|
|
|
parental_block_host: family-block.dns.adguard.com
|
|
|
|
safebrowsing_block_host: standard-block.dns.adguard.com
|
|
|
|
cache_size: 0
|
|
|
|
upstream_dns:
|
|
|
|
- https://1.1.1.1/dns-query
|
|
|
|
filtering_enabled: true
|
|
|
|
filters_update_interval: 168
|
|
|
|
parental_sensitivity: 13
|
|
|
|
parental_enabled: true
|
|
|
|
safesearch_enabled: false
|
|
|
|
safebrowsing_enabled: false
|
|
|
|
safebrowsing_cache_size: 1048576
|
|
|
|
safesearch_cache_size: 1048576
|
|
|
|
parental_cache_size: 1048576
|
|
|
|
cache_time: 30
|
|
|
|
rewrites: []
|
|
|
|
blocked_services: []
|
|
|
|
tls:
|
|
|
|
enabled: false
|
|
|
|
server_name: www.example.com
|
|
|
|
force_https: false
|
|
|
|
port_https: 443
|
|
|
|
port_dns_over_tls: 853
|
2019-12-20 11:50:54 +00:00
|
|
|
allow_unencrypted_doh: true
|
2019-12-11 09:38:58 +00:00
|
|
|
certificate_chain: ""
|
|
|
|
private_key: ""
|
|
|
|
certificate_path: ""
|
|
|
|
private_key_path: ""
|
|
|
|
filters:
|
|
|
|
- enabled: true
|
|
|
|
url: https://adguardteam.github.io/AdGuardSDNSFilter/Filters/filter.txt
|
|
|
|
name: AdGuard Simplified Domain Names filter
|
|
|
|
id: 1
|
|
|
|
- enabled: false
|
|
|
|
url: https://hosts-file.net/ad_servers.txt
|
|
|
|
name: hpHosts - Ad and Tracking servers only
|
|
|
|
id: 2
|
|
|
|
- enabled: false
|
|
|
|
url: https://adaway.org/hosts.txt
|
|
|
|
name: adaway
|
|
|
|
id: 3
|
|
|
|
user_rules:
|
|
|
|
- ""
|
|
|
|
dhcp:
|
|
|
|
enabled: false
|
|
|
|
interface_name: ""
|
|
|
|
gateway_ip: ""
|
|
|
|
subnet_mask: ""
|
|
|
|
range_start: ""
|
|
|
|
range_end: ""
|
|
|
|
lease_duration: 86400
|
|
|
|
icmp_timeout_msec: 1000
|
|
|
|
clients: []
|
|
|
|
log_file: ""
|
|
|
|
verbose: false
|
|
|
|
schema_version: 5
|
|
|
|
`
|
|
|
|
|
|
|
|
// . Create a configuration file
|
|
|
|
// . Start AGH instance
|
|
|
|
// . Check Web server
|
|
|
|
// . Check DNS server
|
2019-12-20 11:50:54 +00:00
|
|
|
// . Check DNS server with DOH
|
2019-12-11 09:38:58 +00:00
|
|
|
// . Wait until the filters are downloaded
|
|
|
|
// . Stop and cleanup
|
|
|
|
func TestHome(t *testing.T) {
|
2020-04-15 13:17:57 +01:00
|
|
|
// Init new context
|
2020-02-13 15:42:07 +00:00
|
|
|
Context = homeContext{}
|
|
|
|
|
2019-12-11 09:38:58 +00:00
|
|
|
dir := prepareTestDir()
|
|
|
|
defer func() { _ = os.RemoveAll(dir) }()
|
|
|
|
fn := filepath.Join(dir, "AdGuardHome.yaml")
|
|
|
|
|
2020-04-15 12:11:31 +01:00
|
|
|
// Prepare the test config
|
2021-01-13 13:56:05 +00:00
|
|
|
assert.Nil(t, ioutil.WriteFile(fn, []byte(yamlConf), 0o644))
|
2019-12-11 09:38:58 +00:00
|
|
|
fn, _ = filepath.Abs(fn)
|
|
|
|
|
2020-01-21 09:58:55 +00:00
|
|
|
config = configuration{} // the global variable is dirty because of the previous tests run
|
2019-12-11 09:38:58 +00:00
|
|
|
args := options{}
|
|
|
|
args.configFilename = fn
|
|
|
|
args.workDir = dir
|
|
|
|
go run(args)
|
|
|
|
|
|
|
|
var err error
|
|
|
|
var resp *http.Response
|
|
|
|
h := http.Client{}
|
2020-02-13 15:42:07 +00:00
|
|
|
for i := 0; i != 50; i++ {
|
2019-12-11 09:38:58 +00:00
|
|
|
resp, err = h.Get("http://127.0.0.1:3000/")
|
|
|
|
if err == nil && resp.StatusCode != 404 {
|
|
|
|
break
|
|
|
|
}
|
2020-02-13 15:42:07 +00:00
|
|
|
time.Sleep(100 * time.Millisecond)
|
2019-12-11 09:38:58 +00:00
|
|
|
}
|
2021-01-13 13:56:05 +00:00
|
|
|
assert.Nilf(t, err, "%s", err)
|
2020-04-15 13:17:57 +01:00
|
|
|
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
2019-12-11 09:38:58 +00:00
|
|
|
|
|
|
|
resp, err = h.Get("http://127.0.0.1:3000/control/status")
|
2021-01-13 13:56:05 +00:00
|
|
|
assert.Nilf(t, err, "%s", err)
|
2020-04-15 13:17:57 +01:00
|
|
|
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
2019-12-11 09:38:58 +00:00
|
|
|
|
2019-12-20 11:50:54 +00:00
|
|
|
// test DNS over UDP
|
2020-08-21 13:54:16 +01:00
|
|
|
r, err := upstream.NewResolver("127.0.0.1:5354", 3*time.Second)
|
|
|
|
assert.Nil(t, err)
|
2019-12-11 09:38:58 +00:00
|
|
|
addrs, err := r.LookupIPAddr(context.TODO(), "static.adguard.com")
|
2020-02-13 15:42:07 +00:00
|
|
|
assert.Nil(t, err)
|
2019-12-11 09:38:58 +00:00
|
|
|
haveIP := len(addrs) != 0
|
|
|
|
assert.True(t, haveIP)
|
|
|
|
|
2019-12-20 11:50:54 +00:00
|
|
|
// test DNS over HTTP without encryption
|
|
|
|
req := dns.Msg{}
|
|
|
|
req.Id = dns.Id()
|
|
|
|
req.RecursionDesired = true
|
|
|
|
req.Question = []dns.Question{{Name: "static.adguard.com.", Qtype: dns.TypeA, Qclass: dns.ClassINET}}
|
|
|
|
buf, err := req.Pack()
|
2021-01-13 13:56:05 +00:00
|
|
|
assert.Nil(t, err)
|
2019-12-20 11:50:54 +00:00
|
|
|
requestURL := "http://127.0.0.1:3000/dns-query?dns=" + base64.RawURLEncoding.EncodeToString(buf)
|
|
|
|
resp, err = http.DefaultClient.Get(requestURL)
|
2021-01-13 13:56:05 +00:00
|
|
|
assert.Nil(t, err)
|
2019-12-20 11:50:54 +00:00
|
|
|
body, err := ioutil.ReadAll(resp.Body)
|
2021-01-13 13:56:05 +00:00
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.Equal(t, http.StatusOK, resp.StatusCode)
|
2019-12-20 11:50:54 +00:00
|
|
|
response := dns.Msg{}
|
|
|
|
err = response.Unpack(body)
|
2021-01-13 13:56:05 +00:00
|
|
|
assert.Nil(t, err)
|
2019-12-20 11:50:54 +00:00
|
|
|
addrs = nil
|
|
|
|
proxyutil.AppendIPAddrs(&addrs, response.Answer)
|
|
|
|
haveIP = len(addrs) != 0
|
|
|
|
assert.True(t, haveIP)
|
|
|
|
|
2019-12-11 09:38:58 +00:00
|
|
|
for i := 1; ; i++ {
|
|
|
|
st, err := os.Stat(filepath.Join(dir, "data", "filters", "1.txt"))
|
|
|
|
if err == nil && st.Size() != 0 {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
if i == 5 {
|
|
|
|
assert.True(t, false)
|
|
|
|
break
|
|
|
|
}
|
|
|
|
time.Sleep(1 * time.Second)
|
|
|
|
}
|
|
|
|
|
|
|
|
cleanup()
|
|
|
|
cleanupAlways()
|
|
|
|
}
|