Merge "misc/docker: bucket.List + CAMLI_GOPHERJS_GOROOT fixes"

This commit is contained in:
Mathieu Lonjaret 2017-01-20 19:32:44 +00:00 committed by Gerrit Code Review
commit bae3cfeeb8
5 changed files with 35 additions and 9 deletions

View File

@ -18,5 +18,5 @@ use -upload=true to directly upload the zip file to the camlistore-release/0.10/
** How to generate a monthly release: ** ** How to generate a monthly release: **
go run ./misc/monthly.go -rev=$GIT_REVISION go run ./misc/monthly.go -rev=$GIT_REVISION -stats_from=cf0c847fbf7e3e48ef463e86674520a4da9aedbb
git commit -m 'monthly release' doc/release/monthly.html git commit -m 'monthly release' doc/release/monthly.html

View File

@ -10,3 +10,13 @@ WORKDIR /tmp
RUN curl -O https://storage.googleapis.com/golang/go1.8rc2.linux-amd64.tar.gz RUN curl -O https://storage.googleapis.com/golang/go1.8rc2.linux-amd64.tar.gz
RUN echo 'd62c2d44d0c6b434e3cda12505f3c9fb880757e3396af1e9ba861f7b547cc864 go1.8rc2.linux-amd64.tar.gz' | sha256sum -c RUN echo 'd62c2d44d0c6b434e3cda12505f3c9fb880757e3396af1e9ba861f7b547cc864 go1.8rc2.linux-amd64.tar.gz' | sha256sum -c
RUN tar -C /usr/local -xzf go1.8rc2.linux-amd64.tar.gz RUN tar -C /usr/local -xzf go1.8rc2.linux-amd64.tar.gz
# Adding Go 1.7 as well for gopherjs. Not all our docker images need to do a full
# 'go run make.go', but I feel maintaining two different go docker images would
# not be worth the trouble. We can just remove that as soon as gopherjs supports
# Go 1.8.
WORKDIR /tmp
RUN curl -O https://storage.googleapis.com/golang/go1.7.4.linux-amd64.tar.gz
RUN echo '47fda42e46b4c3ec93fa5d4d4cc6a748aa3f9411a2a2b7e08e3a6d80d753ec8b go1.7.4.linux-amd64.tar.gz' | sha256sum -c
RUN tar -xzf go1.7.4.linux-amd64.tar.gz
RUN mv go /usr/local/go1.7

View File

@ -148,6 +148,7 @@ func build() {
oldPath := os.Getenv("PATH") oldPath := os.Getenv("PATH")
os.Setenv("GOPATH", "/gopath") os.Setenv("GOPATH", "/gopath")
os.Setenv("PATH", "/usr/local/go/bin:"+oldPath) os.Setenv("PATH", "/usr/local/go/bin:"+oldPath)
check(os.Setenv("CAMLI_GOPHERJS_GOROOT", "/usr/local/go1.7"))
cmd := exec.Command("go", "run", "make.go", "--os", *buildOS) cmd := exec.Command("go", "run", "make.go", "--os", *buildOS)
cmd.Stdout = os.Stdout cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr cmd.Stderr = os.Stderr

View File

@ -259,6 +259,7 @@ func checkBuild() {
} }
check(os.Chdir(tarballSrc)) check(os.Chdir(tarballSrc))
check(os.Setenv("PATH", os.Getenv("PATH")+":/usr/local/go/bin/")) check(os.Setenv("PATH", os.Getenv("PATH")+":/usr/local/go/bin/"))
check(os.Setenv("CAMLI_GOPHERJS_GOROOT", "/usr/local/go1.7"))
cmd := exec.Command("go", "run", "make.go") cmd := exec.Command("go", "run", "make.go")
cmd.Stdout = os.Stdout cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr cmd.Stderr = os.Stderr

View File

@ -48,6 +48,7 @@ import (
"golang.org/x/net/context" "golang.org/x/net/context"
"golang.org/x/oauth2" "golang.org/x/oauth2"
"golang.org/x/oauth2/google" "golang.org/x/oauth2/google"
"google.golang.org/api/iterator"
"google.golang.org/api/option" "google.golang.org/api/option"
) )
@ -55,7 +56,7 @@ var (
flagRev = flag.String("rev", "", "Camlistore revision to build (tag or commit hash). For development purposes, you can instead specify the path to a local Camlistore source tree from which to build, with the form \"WIP:/path/to/dir\".") flagRev = flag.String("rev", "", "Camlistore revision to build (tag or commit hash). For development purposes, you can instead specify the path to a local Camlistore source tree from which to build, with the form \"WIP:/path/to/dir\".")
flagDate = flag.String("date", "", "The release date to use in the file names to be uploaded, in the YYYYMMDD format. Defaults to today's date.") flagDate = flag.String("date", "", "The release date to use in the file names to be uploaded, in the YYYYMMDD format. Defaults to today's date.")
flagUpload = flag.Bool("upload", true, "Upload all the generated tarballs and zip archives.") flagUpload = flag.Bool("upload", true, "Upload all the generated tarballs and zip archives.")
flagSkipGen = flag.Bool("skipgen", false, "Do not recreate the release tarballs, and directly use the ones found in camlistore.org/misc/docker/release. Use -upload=true and -skipgen=true to only generate the monthly release page.") flagSkipGen = flag.Bool("skipgen", false, "Do not recreate the release tarballs, and directly use the ones found in camlistore.org/misc/docker/release. Use -upload=false and -skipgen=true to only generate the monthly release page.")
flagStatsFrom = flag.String("stats_from", "", "Also generate commit statistics on the release page, starting from the given commit, and ending at the one given as -rev.") flagStatsFrom = flag.String("stats_from", "", "Also generate commit statistics on the release page, starting from the given commit, and ending at the one given as -rev.")
// TODO(mpl): make sanity run the tests too, once they're more reliable. // TODO(mpl): make sanity run the tests too, once they're more reliable.
flagSanity = flag.Bool("sanity", true, "Verify 'go run make.go' succeeds when building the source tarball. Abort everything if not.") flagSanity = flag.Bool("sanity", true, "Verify 'go run make.go' succeeds when building the source tarball. Abort everything if not.")
@ -275,7 +276,7 @@ Camlistore version <a href='https://github.com/camlistore/camlistore/commit/{{.C
// TODO(mpl): keep goVersion automatically in sync with version in // TODO(mpl): keep goVersion automatically in sync with version in
// misc/docker/go. Or guess it from somewhere else. // misc/docker/go. Or guess it from somewhere else.
const goVersion = "1.7" const goVersion = "1.8rc2"
// listDownloads lists all the files found in the monthly repo, and from them, // listDownloads lists all the files found in the monthly repo, and from them,
// builds the data that we'll feed to the template to generate the monthly // builds the data that we'll feed to the template to generate the monthly
@ -290,10 +291,6 @@ func listDownloads() (*ReleaseData, error) {
if err != nil { if err != nil {
return nil, err return nil, err
} }
objList, err := stoClient.Bucket(bucket).List(ctx, &storage.Query{Prefix: "monthly/"})
if err != nil {
return nil, err
}
platformBySuffix := map[string]string{ platformBySuffix := map[string]string{
"src.zip": "Source", "src.zip": "Source",
@ -341,7 +338,16 @@ func listDownloads() (*ReleaseData, error) {
nameToSum = make(map[string]string) nameToSum = make(map[string]string)
) )
fileDate := releaseDate.Format(fileDateFormat) fileDate := releaseDate.Format(fileDateFormat)
for _, attrs := range objList.Results { log.Printf("Now looking for monthly/camlistore-%s-* files in bucket", fileDate)
objIt := stoClient.Bucket(bucket).Objects(ctx, &storage.Query{Prefix: "monthly/"})
for {
attrs, err := objIt.Next()
if err == iterator.Done {
break
}
if err != nil {
return nil, fmt.Errorf("error listing objects in \"monthly\": %v", err)
}
if !strings.Contains(attrs.Name, fileDate) { if !strings.Contains(attrs.Name, fileDate) {
continue continue
} }
@ -357,7 +363,15 @@ func listDownloads() (*ReleaseData, error) {
} }
nameToSum[strings.TrimSuffix(attrs.Name, ".sha256")] = sum nameToSum[strings.TrimSuffix(attrs.Name, ".sha256")] = sum
} }
for _, attrs := range objList.Results { objIt = stoClient.Bucket(bucket).Objects(ctx, &storage.Query{Prefix: "monthly/"})
for {
attrs, err := objIt.Next()
if err == iterator.Done {
break
}
if err != nil {
return nil, fmt.Errorf("error listing objects in \"monthly\": %v", err)
}
if !strings.Contains(attrs.Name, fileDate) { if !strings.Contains(attrs.Name, fileDate) {
continue continue
} }