From 7001483b621d8b906e16a1c19bdc34908b775964 Mon Sep 17 00:00:00 2001 From: Felix Yan Date: Thu, 3 Sep 2020 16:00:24 +0800 Subject: [PATCH] Don't copy assets if they are already present They can now reside in system path (like /usr/share/v2ray), so it's not possible to copy into there. --- app/router/condition_geoip_test.go | 8 ++++++-- app/router/condition_test.go | 8 ++++++-- infra/conf/dns_test.go | 4 +++- 3 files changed, 15 insertions(+), 5 deletions(-) diff --git a/app/router/condition_geoip_test.go b/app/router/condition_geoip_test.go index 38e05373..c92d990b 100644 --- a/app/router/condition_geoip_test.go +++ b/app/router/condition_geoip_test.go @@ -17,8 +17,12 @@ func init() { wd, err := os.Getwd() common.Must(err) - common.Must(filesystem.CopyFile(platform.GetAssetLocation("geoip.dat"), filepath.Join(wd, "..", "..", "release", "config", "geoip.dat"))) - common.Must(filesystem.CopyFile(platform.GetAssetLocation("geosite.dat"), filepath.Join(wd, "..", "..", "release", "config", "geosite.dat"))) + if _, err := os.Stat(platform.GetAssetLocation("geoip.dat")); err != nil && os.IsNotExist(err) { + common.Must(filesystem.CopyFile(platform.GetAssetLocation("geoip.dat"), filepath.Join(wd, "..", "..", "release", "config", "geoip.dat"))) + } + if _, err := os.Stat(platform.GetAssetLocation("geosite.dat")); err != nil && os.IsNotExist(err) { + common.Must(filesystem.CopyFile(platform.GetAssetLocation("geosite.dat"), filepath.Join(wd, "..", "..", "release", "config", "geosite.dat"))) + } } func TestGeoIPMatcherContainer(t *testing.T) { diff --git a/app/router/condition_test.go b/app/router/condition_test.go index 20ead4ba..0c0f48f3 100644 --- a/app/router/condition_test.go +++ b/app/router/condition_test.go @@ -23,8 +23,12 @@ func init() { wd, err := os.Getwd() common.Must(err) - common.Must(filesystem.CopyFile(platform.GetAssetLocation("geoip.dat"), filepath.Join(wd, "..", "..", "release", "config", "geoip.dat"))) - common.Must(filesystem.CopyFile(platform.GetAssetLocation("geosite.dat"), filepath.Join(wd, "..", "..", "release", "config", "geosite.dat"))) + if _, err := os.Stat(platform.GetAssetLocation("geoip.dat")); err != nil && os.IsNotExist(err) { + common.Must(filesystem.CopyFile(platform.GetAssetLocation("geoip.dat"), filepath.Join(wd, "..", "..", "release", "config", "geoip.dat"))) + } + if _, err := os.Stat(platform.GetAssetLocation("geosite.dat")); err != nil && os.IsNotExist(err) { + common.Must(filesystem.CopyFile(platform.GetAssetLocation("geosite.dat"), filepath.Join(wd, "..", "..", "release", "config", "geosite.dat"))) + } } func withOutbound(outbound *session.Outbound) *Context { diff --git a/infra/conf/dns_test.go b/infra/conf/dns_test.go index 1725af7c..25111c51 100644 --- a/infra/conf/dns_test.go +++ b/infra/conf/dns_test.go @@ -20,7 +20,9 @@ func init() { wd, err := os.Getwd() common.Must(err) - common.Must(filesystem.CopyFile(platform.GetAssetLocation("geoip.dat"), filepath.Join(wd, "..", "..", "release", "config", "geoip.dat"))) + if _, err := os.Stat(platform.GetAssetLocation("geosite.dat")); err != nil && os.IsNotExist(err) { + common.Must(filesystem.CopyFile(platform.GetAssetLocation("geosite.dat"), filepath.Join(wd, "..", "..", "release", "config", "geosite.dat"))) + } geositeFilePath := platform.GetAssetLocation("geosite.dat") geositeFile, err := os.OpenFile(geositeFilePath, os.O_CREATE|os.O_WRONLY, 0600)