Commit 30678788 authored by Russ Cox's avatar Russ Cox

cmd/go/internal/modfetch: make subdirectories unwritable too

The top-level directory in a module was marked unwritable
but not the subdirectories. Fix that.

Change-Id: Ia57e5343624753851d9fe1ddfe496b870b67f924
Reviewed-on: https://go-review.googlesource.com/124381
Run-TryBot: Russ Cox <rsc@golang.org>
Reviewed-by: default avatarBryan C. Mills <bcmills@google.com>
parent 5c622a5b
...@@ -146,7 +146,7 @@ func Unzip(dir, zipfile, prefix string, maxSize int64) error { ...@@ -146,7 +146,7 @@ func Unzip(dir, zipfile, prefix string, maxSize int64) error {
// Run over list backward to chmod children before parents. // Run over list backward to chmod children before parents.
for i := len(dirlist) - 1; i >= 0; i-- { for i := len(dirlist) - 1; i >= 0; i-- {
os.Chmod(dir, 0555) os.Chmod(dirlist[i], 0555)
} }
return nil return nil
......
...@@ -1037,8 +1037,7 @@ func TestModList(t *testing.T) { ...@@ -1037,8 +1037,7 @@ func TestModList(t *testing.T) {
`), 0666)) `), 0666))
tg.must(ioutil.WriteFile(tg.path("x/go.mod"), []byte(` tg.must(ioutil.WriteFile(tg.path("x/go.mod"), []byte(`
module x module x
require rsc.io/quote v1.5.1 require rsc.io/quote v1.5.2
replace rsc.io/sampler v1.3.0 => rsc.io/sampler v1.3.1
`), 0666)) `), 0666))
tg.cd(tg.path("x")) tg.cd(tg.path("x"))
...@@ -1051,7 +1050,7 @@ func TestModList(t *testing.T) { ...@@ -1051,7 +1050,7 @@ func TestModList(t *testing.T) {
tg.grepStdoutNot(`quote@`, "should not have local copy of code") tg.grepStdoutNot(`quote@`, "should not have local copy of code")
tg.run("list", "-f={{.Dir}}", "rsc.io/quote") // downloads code to load package tg.run("list", "-f={{.Dir}}", "rsc.io/quote") // downloads code to load package
tg.grepStdout(`mod[\\/]rsc.io[\\/]quote@v1.5.1`, "expected cached copy of code") tg.grepStdout(`mod[\\/]rsc.io[\\/]quote@v1.5.2`, "expected cached copy of code")
dir := strings.TrimSpace(tg.getStdout()) dir := strings.TrimSpace(tg.getStdout())
info, err := os.Stat(dir) info, err := os.Stat(dir)
if err != nil { if err != nil {
...@@ -1060,7 +1059,21 @@ func TestModList(t *testing.T) { ...@@ -1060,7 +1059,21 @@ func TestModList(t *testing.T) {
if info.Mode()&0222 != 0 { if info.Mode()&0222 != 0 {
t.Fatalf("%s should be unwritable", dir) t.Fatalf("%s should be unwritable", dir)
} }
info, err = os.Stat(filepath.Join(dir, "buggy"))
if err != nil {
t.Fatal(err)
}
if info.Mode()&0222 != 0 {
t.Fatalf("%s should be unwritable", filepath.Join(dir, "buggy"))
}
tg.must(ioutil.WriteFile(tg.path("x/go.mod"), []byte(`
module x
require rsc.io/quote v1.5.1
replace rsc.io/sampler v1.3.0 => rsc.io/sampler v1.3.1
`), 0666))
tg.run("list", "-f={{.Dir}}", "rsc.io/quote") // downloads code to load package
tg.run("list", "-m", "-f={{.Path}} {{.Version}} {{.Dir}}{{with .Replace}} => {{.Version}} {{.Dir}}{{end}}", "all") tg.run("list", "-m", "-f={{.Path}} {{.Version}} {{.Dir}}{{with .Replace}} => {{.Version}} {{.Dir}}{{end}}", "all")
tg.grepStdout(`mod[\\/]rsc.io[\\/]quote@v1.5.1`, "expected cached copy of code") tg.grepStdout(`mod[\\/]rsc.io[\\/]quote@v1.5.1`, "expected cached copy of code")
tg.grepStdout(`v1.3.0 .*mod[\\/]rsc.io[\\/]sampler@v1.3.1 => v1.3.1 .*@v1.3.1`, "expected v1.3.1 replacement") tg.grepStdout(`v1.3.0 .*mod[\\/]rsc.io[\\/]sampler@v1.3.1 => v1.3.1 .*@v1.3.1`, "expected v1.3.1 replacement")
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment