Skip to content

Commit

Permalink
testserver: short circuit downloading before making a request
Browse files Browse the repository at this point in the history
Previously, the testserver would always make a get request to download
the cockroach binary. This commit short circuits the download logic to
avoid making the initial request if the file already exists.
  • Loading branch information
pawalt committed Nov 17, 2023
1 parent 687b669 commit 2e712c1
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 20 deletions.
54 changes: 36 additions & 18 deletions testserver/binaries.go
Original file line number Diff line number Diff line change
Expand Up @@ -57,12 +57,12 @@ const updatesUrl = "https://register.cockroachdb.com/api/updates"

var muslRE = regexp.MustCompile(`(?i)\bmusl\b`)

// GetDownloadResponse return the http response of a CRDB download.
// It creates the url for downloading a CRDB binary for current runtime OS,
// makes a request to this url, and return the response.
// nonStable should only be used if desiredVersion is not specified. If nonStable
// is used, the latest cockroach binary will be used.
func GetDownloadResponse(desiredVersion string, nonStable bool) (*http.Response, string, error) {
// GetDownloadURL returns the URL of a CRDB download. It creates the URL for
// downloading a CRDB binary for current runtime OS. If desiredVersion is
// specified, it will return the URL of the specified version. Otherwise, it
// will return the URL of the latest stable cockroach binary. If nonStable is
// true, the latest cockroach binary will be used.
func GetDownloadURL(desiredVersion string, nonStable bool) (string, string, error) {
goos := runtime.GOOS
if goos == "linux" {
goos += func() string {
Expand Down Expand Up @@ -100,21 +100,31 @@ func GetDownloadResponse(desiredVersion string, nonStable bool) (*http.Response,
// For the latest stable CRDB, we use the url provided in the CRDB release page.
dbUrl, desiredVersion, err = getLatestStableVersionInfo()
if err != nil {
return nil, "", err
return dbUrl, "", err
}
}

log.Printf("GET %s", dbUrl)
response, err := http.Get(dbUrl)
return dbUrl, desiredVersion, nil
}

// DownloadFromURL starts a download of the cockroach binary from the given URL.
func DownloadFromURL(downloadURL string) (*http.Response, error) {
log.Printf("GET %s", downloadURL)
response, err := http.Get(downloadURL)
if err != nil {
return nil, "", err
return nil, err
}

if response.StatusCode != 200 {
return nil, "", fmt.Errorf("error downloading %s: %d (%s)", dbUrl,
response.StatusCode, response.Status)
return nil, fmt.Errorf(
"error downloading %s: %d (%s)",
downloadURL,
response.StatusCode,
response.Status,
)
}
return response, desiredVersion, nil

return response, nil
}

// DownloadBinary saves the latest version of CRDB into a local binary file,
Expand All @@ -124,19 +134,27 @@ func GetDownloadResponse(desiredVersion string, nonStable bool) (*http.Response,
// To download the latest STABLE version of CRDB, set `nonStable` to false.
// To download the bleeding edge version of CRDB, set `nonStable` to true.
func DownloadBinary(tc *TestConfig, desiredVersion string, nonStable bool) (string, error) {
response, desiredVersion, err := GetDownloadResponse(desiredVersion, nonStable)
dbUrl, desiredVersion, err := GetDownloadURL(desiredVersion, nonStable)

Check failure on line 137 in testserver/binaries.go

View workflow job for this annotation

GitHub Actions / build-and-test (1.18)

this value of err is never used (SA4006)

Check failure on line 137 in testserver/binaries.go

View workflow job for this annotation

GitHub Actions / build-and-test (1.19)

this value of err is never used (SA4006)

filename, err := GetDownloadFilename(desiredVersion)
if err != nil {
return "", err
}
localFile := filepath.Join(os.TempDir(), filename)

defer func() { _ = response.Body.Close() }()
// Short circuit if the file already exists and is in the finished state.
info, err := os.Stat(localFile)
if err == nil && info.Mode().Perm() == finishedFileMode {
return localFile, nil
}

filename, err := GetDownloadFilename(response, nonStable, desiredVersion)
response, err := DownloadFromURL(dbUrl)
if err != nil {
return "", err
}

localFile := filepath.Join(os.TempDir(), filename)
defer func() { _ = response.Body.Close() }()

for {
info, err := os.Stat(localFile)
if os.IsNotExist(err) {
Expand Down Expand Up @@ -229,7 +247,7 @@ func DownloadBinary(tc *TestConfig, desiredVersion string, nonStable bool) (stri

// GetDownloadFilename returns the local filename of the downloaded CRDB binary file.
func GetDownloadFilename(
response *http.Response, nonStableDB bool, desiredVersion string,
desiredVersion string,
) (string, error) {
filename := fmt.Sprintf("cockroach-%s", desiredVersion)
if runtime.GOOS == "windows" {
Expand Down
4 changes: 2 additions & 2 deletions testserver/testserver_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -762,11 +762,11 @@ func testFlockWithDownloadKilled(t *testing.T) (*sql.DB, func()) {

// getLocalFile returns the to-be-downloaded CRDB binary's local path.
func getLocalFile(nonStable bool) (string, error) {
response, latestStableVersion, err := testserver.GetDownloadResponse("", nonStable)
_, latestStableVersion, err := testserver.GetDownloadURL("", nonStable)
if err != nil {
return "", err
}
filename, err := testserver.GetDownloadFilename(response, nonStable, latestStableVersion)
filename, err := testserver.GetDownloadFilename(latestStableVersion)
if err != nil {
return "", err
}
Expand Down

0 comments on commit 2e712c1

Please sign in to comment.