2021-04-11 17:56:55 +08:00
|
|
|
package sync
|
2021-04-11 16:45:10 +08:00
|
|
|
|
|
|
|
import (
|
2021-04-11 17:56:55 +08:00
|
|
|
"errors"
|
2021-04-19 00:04:53 +08:00
|
|
|
|
2021-08-19 13:41:00 +08:00
|
|
|
"github.com/bakito/adguardhome-sync/pkg/client"
|
|
|
|
clientmock "github.com/bakito/adguardhome-sync/pkg/mocks/client"
|
2021-04-11 17:56:55 +08:00
|
|
|
"github.com/bakito/adguardhome-sync/pkg/types"
|
|
|
|
gm "github.com/golang/mock/gomock"
|
|
|
|
"github.com/google/uuid"
|
2021-12-10 05:55:38 +08:00
|
|
|
. "github.com/onsi/ginkgo/v2"
|
2021-11-30 05:25:01 +08:00
|
|
|
. "github.com/onsi/gomega"
|
2021-04-11 16:45:10 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
var _ = Describe("Sync", func() {
|
2021-04-11 17:56:55 +08:00
|
|
|
var (
|
|
|
|
mockCtrl *gm.Controller
|
2021-08-19 13:41:00 +08:00
|
|
|
cl *clientmock.MockClient
|
2021-04-11 17:56:55 +08:00
|
|
|
w *worker
|
|
|
|
te error
|
|
|
|
)
|
|
|
|
|
|
|
|
BeforeEach(func() {
|
|
|
|
mockCtrl = gm.NewController(GinkgoT())
|
2021-08-19 13:41:00 +08:00
|
|
|
cl = clientmock.NewMockClient(mockCtrl)
|
2021-04-11 23:30:47 +08:00
|
|
|
w = &worker{
|
|
|
|
createClient: func(instance types.AdGuardInstance) (client.Client, error) {
|
|
|
|
return cl, nil
|
|
|
|
},
|
2021-11-02 01:20:14 +08:00
|
|
|
cfg: &types.Config{
|
|
|
|
Features: types.Features{
|
|
|
|
DHCP: types.DHCP{
|
|
|
|
ServerConfig: true,
|
|
|
|
StaticLeases: true,
|
|
|
|
},
|
|
|
|
DNS: types.DNS{
|
|
|
|
ServerConfig: true,
|
|
|
|
Rewrites: true,
|
|
|
|
AccessLists: true,
|
|
|
|
},
|
|
|
|
Filters: true,
|
|
|
|
ClientSettings: true,
|
|
|
|
Services: true,
|
|
|
|
GeneralSettings: true,
|
|
|
|
StatsConfig: true,
|
|
|
|
QueryLogConfig: true,
|
|
|
|
},
|
|
|
|
},
|
2021-04-11 23:30:47 +08:00
|
|
|
}
|
2021-04-11 17:56:55 +08:00
|
|
|
te = errors.New(uuid.NewString())
|
|
|
|
})
|
|
|
|
AfterEach(func() {
|
|
|
|
defer mockCtrl.Finish()
|
|
|
|
})
|
|
|
|
|
|
|
|
Context("worker", func() {
|
|
|
|
Context("syncRewrites", func() {
|
|
|
|
var (
|
|
|
|
domain string
|
|
|
|
answer string
|
|
|
|
reO types.RewriteEntries
|
|
|
|
reR types.RewriteEntries
|
|
|
|
)
|
2021-04-11 16:45:10 +08:00
|
|
|
|
2021-04-11 17:56:55 +08:00
|
|
|
BeforeEach(func() {
|
|
|
|
domain = uuid.NewString()
|
|
|
|
answer = uuid.NewString()
|
|
|
|
reO = []types.RewriteEntry{{Domain: domain, Answer: answer}}
|
|
|
|
reR = []types.RewriteEntry{{Domain: domain, Answer: answer}}
|
|
|
|
})
|
|
|
|
It("should have no changes (empty slices)", func() {
|
2021-04-11 23:30:47 +08:00
|
|
|
cl.EXPECT().RewriteList().Return(&reR, nil)
|
|
|
|
cl.EXPECT().AddRewriteEntries()
|
|
|
|
cl.EXPECT().DeleteRewriteEntries()
|
2021-08-08 17:07:08 +08:00
|
|
|
err := w.syncRewrites(l, &reO, cl)
|
2021-04-11 17:56:55 +08:00
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should add one rewrite entry", func() {
|
|
|
|
reR = []types.RewriteEntry{}
|
2021-04-11 23:30:47 +08:00
|
|
|
cl.EXPECT().RewriteList().Return(&reR, nil)
|
|
|
|
cl.EXPECT().AddRewriteEntries(reO[0])
|
|
|
|
cl.EXPECT().DeleteRewriteEntries()
|
2021-08-08 17:07:08 +08:00
|
|
|
err := w.syncRewrites(l, &reO, cl)
|
2021-04-11 17:56:55 +08:00
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should remove one rewrite entry", func() {
|
|
|
|
reO = []types.RewriteEntry{}
|
2021-04-11 23:30:47 +08:00
|
|
|
cl.EXPECT().RewriteList().Return(&reR, nil)
|
|
|
|
cl.EXPECT().AddRewriteEntries()
|
|
|
|
cl.EXPECT().DeleteRewriteEntries(reR[0])
|
2021-08-08 17:07:08 +08:00
|
|
|
err := w.syncRewrites(l, &reO, cl)
|
2021-04-11 23:30:47 +08:00
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should remove one rewrite entry", func() {
|
|
|
|
reO = []types.RewriteEntry{}
|
|
|
|
cl.EXPECT().RewriteList().Return(&reR, nil)
|
|
|
|
cl.EXPECT().AddRewriteEntries()
|
|
|
|
cl.EXPECT().DeleteRewriteEntries(reR[0])
|
2021-08-08 17:07:08 +08:00
|
|
|
err := w.syncRewrites(l, &reO, cl)
|
2021-04-11 17:56:55 +08:00
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should return error when error on RewriteList()", func() {
|
2021-04-11 23:30:47 +08:00
|
|
|
cl.EXPECT().RewriteList().Return(nil, te)
|
2021-08-08 17:07:08 +08:00
|
|
|
err := w.syncRewrites(l, &reO, cl)
|
2021-04-11 17:56:55 +08:00
|
|
|
Ω(err).Should(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should return error when error on AddRewriteEntries()", func() {
|
2021-04-11 23:30:47 +08:00
|
|
|
cl.EXPECT().RewriteList().Return(&reR, nil)
|
|
|
|
cl.EXPECT().AddRewriteEntries().Return(te)
|
2021-08-08 17:07:08 +08:00
|
|
|
err := w.syncRewrites(l, &reO, cl)
|
2021-04-11 17:56:55 +08:00
|
|
|
Ω(err).Should(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should return error when error on DeleteRewriteEntries()", func() {
|
2021-04-11 23:30:47 +08:00
|
|
|
cl.EXPECT().RewriteList().Return(&reR, nil)
|
|
|
|
cl.EXPECT().AddRewriteEntries()
|
|
|
|
cl.EXPECT().DeleteRewriteEntries().Return(te)
|
2021-08-08 17:07:08 +08:00
|
|
|
err := w.syncRewrites(l, &reO, cl)
|
2021-04-11 17:56:55 +08:00
|
|
|
Ω(err).Should(HaveOccurred())
|
|
|
|
})
|
|
|
|
})
|
|
|
|
Context("syncClients", func() {
|
|
|
|
var (
|
2021-04-11 23:30:47 +08:00
|
|
|
clO *types.Clients
|
|
|
|
clR *types.Clients
|
|
|
|
name string
|
2021-04-11 17:56:55 +08:00
|
|
|
)
|
|
|
|
BeforeEach(func() {
|
2021-04-11 23:30:47 +08:00
|
|
|
name = uuid.NewString()
|
|
|
|
clO = &types.Clients{Clients: []types.Client{{Name: name}}}
|
|
|
|
clR = &types.Clients{Clients: []types.Client{{Name: name}}}
|
2021-04-11 17:56:55 +08:00
|
|
|
})
|
|
|
|
It("should have no changes (empty slices)", func() {
|
2021-04-11 23:30:47 +08:00
|
|
|
cl.EXPECT().Clients().Return(clR, nil)
|
|
|
|
cl.EXPECT().AddClients()
|
|
|
|
cl.EXPECT().UpdateClients()
|
|
|
|
cl.EXPECT().DeleteClients()
|
|
|
|
err := w.syncClients(clO, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should add one client", func() {
|
|
|
|
clR.Clients = []types.Client{}
|
|
|
|
cl.EXPECT().Clients().Return(clR, nil)
|
|
|
|
cl.EXPECT().AddClients(clO.Clients[0])
|
|
|
|
cl.EXPECT().UpdateClients()
|
|
|
|
cl.EXPECT().DeleteClients()
|
|
|
|
err := w.syncClients(clO, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should update one client", func() {
|
|
|
|
clR.Clients[0].Disallowed = true
|
|
|
|
cl.EXPECT().Clients().Return(clR, nil)
|
|
|
|
cl.EXPECT().AddClients()
|
|
|
|
cl.EXPECT().UpdateClients(clO.Clients[0])
|
|
|
|
cl.EXPECT().DeleteClients()
|
|
|
|
err := w.syncClients(clO, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should delete one client", func() {
|
|
|
|
clO.Clients = []types.Client{}
|
|
|
|
cl.EXPECT().Clients().Return(clR, nil)
|
|
|
|
cl.EXPECT().AddClients()
|
|
|
|
cl.EXPECT().UpdateClients()
|
|
|
|
cl.EXPECT().DeleteClients(clR.Clients[0])
|
|
|
|
err := w.syncClients(clO, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should return error when error on Clients()", func() {
|
|
|
|
cl.EXPECT().Clients().Return(nil, te)
|
|
|
|
err := w.syncClients(clO, cl)
|
|
|
|
Ω(err).Should(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should return error when error on AddClients()", func() {
|
|
|
|
cl.EXPECT().Clients().Return(clR, nil)
|
|
|
|
cl.EXPECT().AddClients().Return(te)
|
|
|
|
err := w.syncClients(clO, cl)
|
|
|
|
Ω(err).Should(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should return error when error on UpdateClients()", func() {
|
|
|
|
cl.EXPECT().Clients().Return(clR, nil)
|
|
|
|
cl.EXPECT().AddClients()
|
|
|
|
cl.EXPECT().UpdateClients().Return(te)
|
|
|
|
err := w.syncClients(clO, cl)
|
|
|
|
Ω(err).Should(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should return error when error on DeleteClients()", func() {
|
|
|
|
cl.EXPECT().Clients().Return(clR, nil)
|
|
|
|
cl.EXPECT().AddClients()
|
|
|
|
cl.EXPECT().UpdateClients()
|
|
|
|
cl.EXPECT().DeleteClients().Return(te)
|
|
|
|
err := w.syncClients(clO, cl)
|
|
|
|
Ω(err).Should(HaveOccurred())
|
|
|
|
})
|
|
|
|
})
|
|
|
|
Context("syncGeneralSettings", func() {
|
|
|
|
var (
|
|
|
|
o *origin
|
|
|
|
rs *types.Status
|
|
|
|
)
|
|
|
|
BeforeEach(func() {
|
|
|
|
o = &origin{
|
|
|
|
status: &types.Status{},
|
|
|
|
}
|
|
|
|
rs = &types.Status{}
|
|
|
|
})
|
|
|
|
It("should have no changes", func() {
|
|
|
|
cl.EXPECT().Parental()
|
|
|
|
cl.EXPECT().SafeSearch()
|
|
|
|
cl.EXPECT().SafeBrowsing()
|
|
|
|
err := w.syncGeneralSettings(o, rs, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should have protection enabled changes", func() {
|
|
|
|
o.status.ProtectionEnabled = true
|
|
|
|
cl.EXPECT().ToggleProtection(true)
|
|
|
|
cl.EXPECT().Parental()
|
|
|
|
cl.EXPECT().SafeSearch()
|
|
|
|
cl.EXPECT().SafeBrowsing()
|
|
|
|
err := w.syncGeneralSettings(o, rs, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should have parental enabled changes", func() {
|
|
|
|
o.parental = true
|
|
|
|
cl.EXPECT().Parental()
|
|
|
|
cl.EXPECT().ToggleParental(true)
|
|
|
|
cl.EXPECT().SafeSearch()
|
|
|
|
cl.EXPECT().SafeBrowsing()
|
|
|
|
err := w.syncGeneralSettings(o, rs, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should have safeSearch enabled changes", func() {
|
|
|
|
o.safeSearch = true
|
|
|
|
cl.EXPECT().Parental()
|
|
|
|
cl.EXPECT().SafeSearch()
|
|
|
|
cl.EXPECT().ToggleSafeSearch(true)
|
|
|
|
cl.EXPECT().SafeBrowsing()
|
|
|
|
err := w.syncGeneralSettings(o, rs, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should have safeBrowsing enabled changes", func() {
|
|
|
|
o.safeBrowsing = true
|
|
|
|
cl.EXPECT().Parental()
|
|
|
|
cl.EXPECT().SafeSearch()
|
|
|
|
cl.EXPECT().SafeBrowsing()
|
|
|
|
cl.EXPECT().ToggleSafeBrowsing(true)
|
|
|
|
err := w.syncGeneralSettings(o, rs, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
})
|
|
|
|
Context("syncConfigs", func() {
|
|
|
|
var (
|
|
|
|
o *origin
|
|
|
|
qlc *types.QueryLogConfig
|
|
|
|
sc *types.IntervalConfig
|
|
|
|
)
|
|
|
|
BeforeEach(func() {
|
|
|
|
o = &origin{
|
|
|
|
queryLogConfig: &types.QueryLogConfig{},
|
|
|
|
statsConfig: &types.IntervalConfig{},
|
|
|
|
}
|
|
|
|
qlc = &types.QueryLogConfig{}
|
|
|
|
sc = &types.IntervalConfig{}
|
|
|
|
})
|
|
|
|
It("should have no changes", func() {
|
|
|
|
cl.EXPECT().QueryLogConfig().Return(qlc, nil)
|
|
|
|
cl.EXPECT().StatsConfig().Return(sc, nil)
|
|
|
|
err := w.syncConfigs(o, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should have QueryLogConfig changes", func() {
|
|
|
|
o.queryLogConfig.Interval = 123
|
|
|
|
cl.EXPECT().QueryLogConfig().Return(qlc, nil)
|
2022-01-10 01:15:54 +08:00
|
|
|
cl.EXPECT().SetQueryLogConfig(false, 123.0, false)
|
2021-04-11 23:30:47 +08:00
|
|
|
cl.EXPECT().StatsConfig().Return(sc, nil)
|
|
|
|
err := w.syncConfigs(o, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should have StatsConfig changes", func() {
|
|
|
|
o.statsConfig.Interval = 123
|
|
|
|
cl.EXPECT().QueryLogConfig().Return(qlc, nil)
|
|
|
|
cl.EXPECT().StatsConfig().Return(sc, nil)
|
2022-01-10 01:15:54 +08:00
|
|
|
cl.EXPECT().SetStatsConfig(123.0)
|
2021-04-11 23:30:47 +08:00
|
|
|
err := w.syncConfigs(o, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
})
|
2021-04-19 04:03:57 +08:00
|
|
|
Context("statusWithSetup", func() {
|
|
|
|
var (
|
|
|
|
status *types.Status
|
|
|
|
inst types.AdGuardInstance
|
|
|
|
)
|
|
|
|
BeforeEach(func() {
|
|
|
|
status = &types.Status{}
|
|
|
|
inst = types.AdGuardInstance{
|
|
|
|
AutoSetup: true,
|
|
|
|
}
|
|
|
|
})
|
|
|
|
It("should get the replica status", func() {
|
|
|
|
cl.EXPECT().Status().Return(status, nil)
|
|
|
|
st, err := w.statusWithSetup(l, inst, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
Ω(st).Should(Equal(status))
|
|
|
|
})
|
|
|
|
It("should runs setup before getting replica status", func() {
|
2021-08-19 13:41:00 +08:00
|
|
|
cl.EXPECT().Status().Return(nil, client.ErrSetupNeeded)
|
2021-04-19 04:03:57 +08:00
|
|
|
cl.EXPECT().Setup()
|
|
|
|
cl.EXPECT().Status().Return(status, nil)
|
|
|
|
st, err := w.statusWithSetup(l, inst, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
Ω(st).Should(Equal(status))
|
|
|
|
})
|
|
|
|
It("should fail on setup", func() {
|
2021-08-19 13:41:00 +08:00
|
|
|
cl.EXPECT().Status().Return(nil, client.ErrSetupNeeded)
|
2021-04-19 04:03:57 +08:00
|
|
|
cl.EXPECT().Setup().Return(te)
|
|
|
|
st, err := w.statusWithSetup(l, inst, cl)
|
|
|
|
Ω(err).Should(HaveOccurred())
|
|
|
|
Ω(st).Should(BeNil())
|
|
|
|
})
|
|
|
|
})
|
2021-04-11 23:30:47 +08:00
|
|
|
Context("syncServices", func() {
|
|
|
|
var (
|
|
|
|
os types.Services
|
|
|
|
rs types.Services
|
|
|
|
)
|
|
|
|
BeforeEach(func() {
|
|
|
|
os = []string{"foo"}
|
|
|
|
rs = []string{"foo"}
|
|
|
|
})
|
|
|
|
It("should have no changes", func() {
|
|
|
|
cl.EXPECT().Services().Return(rs, nil)
|
|
|
|
err := w.syncServices(os, cl)
|
2021-04-11 17:56:55 +08:00
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
2021-04-11 23:30:47 +08:00
|
|
|
It("should have services changes", func() {
|
|
|
|
os = []string{"bar"}
|
|
|
|
cl.EXPECT().Services().Return(rs, nil)
|
|
|
|
cl.EXPECT().SetServices(os)
|
|
|
|
err := w.syncServices(os, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
})
|
|
|
|
Context("syncFilters", func() {
|
|
|
|
var (
|
|
|
|
of *types.FilteringStatus
|
|
|
|
rf *types.FilteringStatus
|
|
|
|
)
|
|
|
|
BeforeEach(func() {
|
|
|
|
of = &types.FilteringStatus{}
|
|
|
|
rf = &types.FilteringStatus{}
|
|
|
|
})
|
|
|
|
It("should have no changes", func() {
|
|
|
|
cl.EXPECT().Filtering().Return(rf, nil)
|
|
|
|
cl.EXPECT().AddFilters(false)
|
|
|
|
cl.EXPECT().UpdateFilters(false)
|
|
|
|
cl.EXPECT().DeleteFilters(false)
|
|
|
|
cl.EXPECT().AddFilters(true)
|
|
|
|
cl.EXPECT().UpdateFilters(true)
|
|
|
|
cl.EXPECT().DeleteFilters(true)
|
|
|
|
err := w.syncFilters(of, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should have changes user roles", func() {
|
|
|
|
of.UserRules = []string{"foo"}
|
|
|
|
cl.EXPECT().Filtering().Return(rf, nil)
|
|
|
|
cl.EXPECT().AddFilters(false)
|
|
|
|
cl.EXPECT().UpdateFilters(false)
|
|
|
|
cl.EXPECT().DeleteFilters(false)
|
|
|
|
cl.EXPECT().AddFilters(true)
|
|
|
|
cl.EXPECT().UpdateFilters(true)
|
|
|
|
cl.EXPECT().DeleteFilters(true)
|
|
|
|
cl.EXPECT().SetCustomRules(of.UserRules)
|
|
|
|
err := w.syncFilters(of, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should have changed filtering config", func() {
|
|
|
|
of.Enabled = true
|
|
|
|
of.Interval = 123
|
|
|
|
cl.EXPECT().Filtering().Return(rf, nil)
|
|
|
|
cl.EXPECT().AddFilters(false)
|
|
|
|
cl.EXPECT().UpdateFilters(false)
|
|
|
|
cl.EXPECT().DeleteFilters(false)
|
|
|
|
cl.EXPECT().AddFilters(true)
|
|
|
|
cl.EXPECT().UpdateFilters(true)
|
|
|
|
cl.EXPECT().DeleteFilters(true)
|
|
|
|
cl.EXPECT().ToggleFiltering(of.Enabled, of.Interval)
|
|
|
|
err := w.syncFilters(of, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
})
|
2021-05-29 02:03:19 +08:00
|
|
|
|
|
|
|
Context("syncDNS", func() {
|
|
|
|
var (
|
|
|
|
oal *types.AccessList
|
|
|
|
ral *types.AccessList
|
|
|
|
odc *types.DNSConfig
|
|
|
|
rdc *types.DNSConfig
|
|
|
|
)
|
|
|
|
BeforeEach(func() {
|
|
|
|
oal = &types.AccessList{}
|
|
|
|
ral = &types.AccessList{}
|
|
|
|
odc = &types.DNSConfig{}
|
|
|
|
rdc = &types.DNSConfig{}
|
|
|
|
})
|
|
|
|
It("should have no changes", func() {
|
|
|
|
cl.EXPECT().AccessList().Return(ral, nil)
|
|
|
|
cl.EXPECT().DNSConfig().Return(rdc, nil)
|
|
|
|
err := w.syncDNS(oal, odc, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should have access list changes", func() {
|
|
|
|
ral.BlockedHosts = []string{"foo"}
|
|
|
|
cl.EXPECT().AccessList().Return(ral, nil)
|
|
|
|
cl.EXPECT().DNSConfig().Return(rdc, nil)
|
|
|
|
cl.EXPECT().SetAccessList(oal)
|
|
|
|
err := w.syncDNS(oal, odc, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
It("should have dns config changes", func() {
|
|
|
|
rdc.Bootstraps = []string{"foo"}
|
|
|
|
cl.EXPECT().AccessList().Return(ral, nil)
|
|
|
|
cl.EXPECT().DNSConfig().Return(rdc, nil)
|
|
|
|
cl.EXPECT().SetDNSConfig(odc)
|
|
|
|
err := w.syncDNS(oal, odc, cl)
|
|
|
|
Ω(err).ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2021-04-11 23:30:47 +08:00
|
|
|
Context("sync", func() {
|
2022-01-10 01:15:54 +08:00
|
|
|
BeforeEach(func() {
|
2021-04-11 23:30:47 +08:00
|
|
|
w.cfg = &types.Config{
|
|
|
|
Origin: types.AdGuardInstance{},
|
|
|
|
Replica: types.AdGuardInstance{URL: "foo"},
|
2021-11-01 15:56:12 +08:00
|
|
|
Features: types.Features{
|
|
|
|
DHCP: types.DHCP{
|
|
|
|
ServerConfig: true,
|
|
|
|
StaticLeases: true,
|
|
|
|
},
|
2021-11-02 01:20:14 +08:00
|
|
|
DNS: types.DNS{
|
|
|
|
ServerConfig: true,
|
|
|
|
Rewrites: true,
|
|
|
|
AccessLists: true,
|
|
|
|
},
|
|
|
|
Filters: true,
|
|
|
|
ClientSettings: true,
|
|
|
|
Services: true,
|
|
|
|
GeneralSettings: true,
|
|
|
|
StatsConfig: true,
|
|
|
|
QueryLogConfig: true,
|
2021-11-01 15:56:12 +08:00
|
|
|
},
|
2021-04-11 23:30:47 +08:00
|
|
|
}
|
2022-01-10 01:15:54 +08:00
|
|
|
})
|
|
|
|
It("should have no changes", func() {
|
2021-04-11 23:30:47 +08:00
|
|
|
// origin
|
|
|
|
cl.EXPECT().Host()
|
2022-01-10 01:15:54 +08:00
|
|
|
cl.EXPECT().Status().Return(&types.Status{Version: minAghVersion}, nil)
|
2021-04-11 23:30:47 +08:00
|
|
|
cl.EXPECT().Parental()
|
|
|
|
cl.EXPECT().SafeSearch()
|
|
|
|
cl.EXPECT().SafeBrowsing()
|
|
|
|
cl.EXPECT().RewriteList().Return(&types.RewriteEntries{}, nil)
|
|
|
|
cl.EXPECT().Services()
|
|
|
|
cl.EXPECT().Filtering().Return(&types.FilteringStatus{}, nil)
|
|
|
|
cl.EXPECT().Clients().Return(&types.Clients{}, nil)
|
|
|
|
cl.EXPECT().QueryLogConfig().Return(&types.QueryLogConfig{}, nil)
|
|
|
|
cl.EXPECT().StatsConfig().Return(&types.IntervalConfig{}, nil)
|
2021-05-29 02:03:19 +08:00
|
|
|
cl.EXPECT().AccessList().Return(&types.AccessList{}, nil)
|
|
|
|
cl.EXPECT().DNSConfig().Return(&types.DNSConfig{}, nil)
|
|
|
|
cl.EXPECT().DHCPServerConfig().Return(&types.DHCPServerConfig{}, nil)
|
2021-04-11 23:30:47 +08:00
|
|
|
|
|
|
|
// replica
|
|
|
|
cl.EXPECT().Host()
|
2022-01-10 01:15:54 +08:00
|
|
|
cl.EXPECT().Status().Return(&types.Status{Version: minAghVersion}, nil)
|
2021-04-11 23:30:47 +08:00
|
|
|
cl.EXPECT().Parental()
|
|
|
|
cl.EXPECT().SafeSearch()
|
|
|
|
cl.EXPECT().SafeBrowsing()
|
|
|
|
cl.EXPECT().QueryLogConfig().Return(&types.QueryLogConfig{}, nil)
|
|
|
|
cl.EXPECT().StatsConfig().Return(&types.IntervalConfig{}, nil)
|
|
|
|
cl.EXPECT().RewriteList().Return(&types.RewriteEntries{}, nil)
|
|
|
|
cl.EXPECT().AddRewriteEntries()
|
|
|
|
cl.EXPECT().DeleteRewriteEntries()
|
|
|
|
cl.EXPECT().Filtering().Return(&types.FilteringStatus{}, nil)
|
|
|
|
cl.EXPECT().AddFilters(false)
|
|
|
|
cl.EXPECT().UpdateFilters(false)
|
|
|
|
cl.EXPECT().DeleteFilters(false)
|
|
|
|
cl.EXPECT().AddFilters(true)
|
|
|
|
cl.EXPECT().UpdateFilters(true)
|
|
|
|
cl.EXPECT().DeleteFilters(true)
|
|
|
|
cl.EXPECT().Services()
|
|
|
|
cl.EXPECT().Clients().Return(&types.Clients{}, nil)
|
|
|
|
cl.EXPECT().AddClients()
|
|
|
|
cl.EXPECT().UpdateClients()
|
|
|
|
cl.EXPECT().DeleteClients()
|
2021-05-29 02:03:19 +08:00
|
|
|
cl.EXPECT().AccessList().Return(&types.AccessList{}, nil)
|
|
|
|
cl.EXPECT().DNSConfig().Return(&types.DNSConfig{}, nil)
|
|
|
|
cl.EXPECT().DHCPServerConfig().Return(&types.DHCPServerConfig{}, nil)
|
|
|
|
cl.EXPECT().AddDHCPStaticLeases().Return(nil)
|
|
|
|
cl.EXPECT().DeleteDHCPStaticLeases().Return(nil)
|
2021-04-11 23:30:47 +08:00
|
|
|
w.sync()
|
|
|
|
})
|
2022-01-10 01:15:54 +08:00
|
|
|
It("origin version is too small", func() {
|
|
|
|
// origin
|
|
|
|
cl.EXPECT().Host()
|
|
|
|
cl.EXPECT().Status().Return(&types.Status{Version: "v0.106.9"}, nil)
|
|
|
|
w.sync()
|
|
|
|
})
|
|
|
|
It("replica version is too small", func() {
|
|
|
|
// origin
|
|
|
|
cl.EXPECT().Host()
|
|
|
|
cl.EXPECT().Status().Return(&types.Status{Version: minAghVersion}, nil)
|
|
|
|
cl.EXPECT().Parental()
|
|
|
|
cl.EXPECT().SafeSearch()
|
|
|
|
cl.EXPECT().SafeBrowsing()
|
|
|
|
cl.EXPECT().RewriteList().Return(&types.RewriteEntries{}, nil)
|
|
|
|
cl.EXPECT().Services()
|
|
|
|
cl.EXPECT().Filtering().Return(&types.FilteringStatus{}, nil)
|
|
|
|
cl.EXPECT().Clients().Return(&types.Clients{}, nil)
|
|
|
|
cl.EXPECT().QueryLogConfig().Return(&types.QueryLogConfig{}, nil)
|
|
|
|
cl.EXPECT().StatsConfig().Return(&types.IntervalConfig{}, nil)
|
|
|
|
cl.EXPECT().AccessList().Return(&types.AccessList{}, nil)
|
|
|
|
cl.EXPECT().DNSConfig().Return(&types.DNSConfig{}, nil)
|
|
|
|
cl.EXPECT().DHCPServerConfig().Return(&types.DHCPServerConfig{}, nil)
|
|
|
|
|
|
|
|
// replica
|
|
|
|
cl.EXPECT().Host()
|
|
|
|
cl.EXPECT().Status().Return(&types.Status{Version: "v0.106.9"}, nil)
|
|
|
|
w.sync()
|
|
|
|
})
|
2021-04-11 17:56:55 +08:00
|
|
|
})
|
|
|
|
})
|
2021-04-11 16:45:10 +08:00
|
|
|
})
|