Best Syzkaller code snippet using asset.UploadBuildAsset
manager.go
Source:manager.go
...693 if _, err := file.Seek(0, io.SeekStart); err != nil {694 log.Logf(0, "failed wind back the opened file for %s: %s", pendingAsset.path, err)695 continue696 }697 info, err := mgr.storage.UploadBuildAsset(file, pendingAsset.name,698 pendingAsset.assetType, build, extra)699 if err != nil {700 log.Logf(0, "failed to upload an asset: %s, %s",701 pendingAsset.path, err)702 continue703 } else if mgr.debugStorage {704 log.Logf(0, "uploaded an asset: %#v", info)705 }706 ret = append(ret, info)707 }708 return ret, nil709}710func (mgr *Manager) uploadCoverReport() error {711 directUpload := mgr.managercfg.Cover && mgr.cfg.CoverUploadPath != ""712 if mgr.storage == nil && !directUpload {713 // Cover report uploading is disabled.714 return nil715 }716 if mgr.storage != nil && directUpload {717 return fmt.Errorf("cover report must be either uploaded directly or via asset storage")718 }719 // Report generation can consume lots of memory. Generate one at a time.720 select {721 case kernelBuildSem <- struct{}{}:722 case <-mgr.stop:723 return nil724 }725 defer func() { <-kernelBuildSem }()726 // Get coverage report from manager.727 addr := mgr.managercfg.HTTP728 if addr != "" && addr[0] == ':' {729 addr = "127.0.0.1" + addr // in case addr is ":port"730 }731 client := http.Client{732 Timeout: time.Hour,733 }734 resp, err := client.Get(fmt.Sprintf("http://%v/cover", addr))735 if err != nil {736 return fmt.Errorf("failed to get report: %v", err)737 }738 defer resp.Body.Close()739 if directUpload {740 return uploadFile(mgr.cfg.CoverUploadPath, mgr.name+".html", resp.Body)741 }742 // Upload via the asset storage.743 newAsset, err := mgr.storage.UploadBuildAsset(resp.Body, mgr.name+".html",744 dashapi.HTMLCoverageReport, mgr.lastBuild, nil)745 if err != nil {746 return fmt.Errorf("failed to upload html coverage report: %w", err)747 }748 err = mgr.storage.ReportBuildAssets(mgr.lastBuild, newAsset)749 if err != nil {750 return fmt.Errorf("failed to report the html coverage report asset: %w", err)751 }752 return nil753}754func (mgr *Manager) uploadCorpus() error {755 f, err := os.Open(filepath.Join(mgr.workDir, "corpus.db"))756 if err != nil {757 return err...
storage_test.go
Source:storage_test.go
...101 return nil102}103func (storage *Storage) sendBuildAsset(reader io.Reader, fileName string, assetType dashapi.AssetType,104 build *dashapi.Build) error {105 asset, err := storage.UploadBuildAsset(reader, fileName, assetType, build, nil)106 if err != nil {107 return err108 }109 return storage.ReportBuildAssets(build, asset)110}111func TestUploadBuildAsset(t *testing.T) {112 dashMock := newDashMock()113 storage, be := makeStorage(t, dashMock.getDashapi())114 be.currentTime = time.Now().Add(-2 * deletionEmbargo)115 build := &dashapi.Build{ID: "1234", KernelCommit: "abcdef2134"}116 // Upload two assets using different means.117 vmLinuxContent := []byte{0xDE, 0xAD, 0xBE, 0xEF}118 dashMock.addBuildAsset = func(newAsset dashapi.NewAsset) error {119 if newAsset.Type != dashapi.KernelObject {120 t.Fatalf("expected KernelObject, got %v", newAsset.Type)121 }122 if !strings.Contains(newAsset.DownloadURL, "vmlinux") {123 t.Fatalf("%#v was expected to mention vmlinux", newAsset.DownloadURL)124 }125 return nil126 }127 var file *uploadedFile128 be.objectUpload = collectBytes(&file)129 err := storage.sendBuildAsset(bytes.NewReader(vmLinuxContent), "vmlinux",130 dashapi.KernelObject, build)131 if err != nil {132 t.Fatalf("file upload failed: %s", err)133 }134 if err := validateXz(file, vmLinuxContent); err != nil {135 t.Fatalf("vmlinux validation failed: %s", err)136 }137 // Upload the same file the second time.138 storage.sendBuildAsset(bytes.NewReader(vmLinuxContent), "vmlinux", dashapi.KernelObject, build)139 // The currently expected behavior is that it will be uploaded twice and will have140 // different names.141 if len(dashMock.downloadURLs) < 2 {142 t.Fatalf("same-file upload was expected to succeed, but it didn't; %#v", dashMock.downloadURLs)143 }144 diskImageContent := []byte{0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8}145 dashMock.addBuildAsset = func(newAsset dashapi.NewAsset) error {146 if newAsset.Type != dashapi.KernelImage {147 t.Fatalf("expected KernelImage, got %v", newAsset.Type)148 }149 if !strings.Contains(newAsset.DownloadURL, "disk") ||150 !strings.Contains(newAsset.DownloadURL, ".img") {151 t.Fatalf("%#v was expected to mention disk.img", newAsset.DownloadURL)152 }153 if !strings.Contains(newAsset.DownloadURL, build.KernelCommit[:6]) {154 t.Fatalf("%#v was expected to mention build commit", newAsset.DownloadURL)155 }156 return nil157 }158 file = nil159 be.objectUpload = collectBytes(&file)160 storage.sendBuildAsset(bytes.NewReader(diskImageContent), "disk.img", dashapi.KernelImage, build)161 if err := validateXz(file, diskImageContent); err != nil {162 t.Fatalf("disk.img validation failed: %s", err)163 }164 allUrls := []string{}165 for url := range dashMock.downloadURLs {166 allUrls = append(allUrls, url)167 }168 if len(allUrls) != 3 {169 t.Fatalf("invalid dashMock state: expected 3 assets, got %d", len(allUrls))170 }171 // First try to remove two assets.172 dashMock.downloadURLs = map[string]bool{allUrls[2]: true, "http://non-related-asset.com/abcd": true}173 // Pretend there's an asset deletion error.174 be.objectRemove = func(string) error { return fmt.Errorf("not now") }175 err = storage.DeprecateAssets()176 if err == nil {177 t.Fatalf("DeprecateAssets() should have failed")178 }179 // Let the deletion be successful.180 be.objectRemove = nil181 err = storage.DeprecateAssets()182 if err != nil {183 t.Fatalf("DeprecateAssets() was expected to be successful, got %s", err)184 }185 path, err := be.getPath(allUrls[2])186 if err != nil {187 t.Fatalf("getPath failed: %s", err)188 }189 err = be.hasOnly([]string{path})190 if err != nil {191 t.Fatalf("after first DeprecateAssets(): %s", err)192 }193 // Delete the rest.194 dashMock.downloadURLs = map[string]bool{}195 err = storage.DeprecateAssets()196 if err != nil || len(be.objects) != 0 {197 t.Fatalf("second DeprecateAssets() failed: %s, len %d",198 err, len(be.objects))199 }200}201type uploadedFile struct {202 req uploadRequest203 bytes []byte204}205func collectBytes(saveTo **uploadedFile) objectUploadCallback {206 return func(req *uploadRequest) (*uploadResponse, error) {207 buf := &bytes.Buffer{}208 wwc := &wrappedWriteCloser{209 writer: buf,210 closeCallback: func() error {211 *saveTo = &uploadedFile{req: *req, bytes: buf.Bytes()}212 return nil213 },214 }215 return &uploadResponse{path: req.savePath, writer: wwc}, nil216 }217}218func TestUploadHtmlAsset(t *testing.T) {219 dashMock := newDashMock()220 storage, be := makeStorage(t, dashMock.getDashapi())221 build := &dashapi.Build{ID: "1234", KernelCommit: "abcdef2134"}222 htmlContent := []byte("<html><head><title>Hi!</title></head></html>")223 dashMock.addBuildAsset = func(newAsset dashapi.NewAsset) error {224 if newAsset.Type != dashapi.HTMLCoverageReport {225 t.Fatalf("expected HtmlCoverageReport, got %v", newAsset.Type)226 }227 if !strings.Contains(newAsset.DownloadURL, "cover_report") {228 t.Fatalf("%#v was expected to mention cover_report", newAsset.DownloadURL)229 }230 if !strings.HasSuffix(newAsset.DownloadURL, ".html") {231 t.Fatalf("%#v was expected to have .html extension", newAsset.DownloadURL)232 }233 return nil234 }235 var file *uploadedFile236 be.objectUpload = collectBytes(&file)237 storage.sendBuildAsset(bytes.NewReader(htmlContent), "cover_report.html",238 dashapi.HTMLCoverageReport, build)239 if err := validateGzip(file, htmlContent); err != nil {240 t.Fatalf("cover_report.html validation failed: %s", err)241 }242}243func TestRecentAssetDeletionProtection(t *testing.T) {244 dashMock := newDashMock()245 storage, be := makeStorage(t, dashMock.getDashapi())246 build := &dashapi.Build{ID: "1234", KernelCommit: "abcdef2134"}247 htmlContent := []byte("<html><head><title>Hi!</title></head></html>")248 be.currentTime = time.Now().Add(-time.Hour * 24 * 6)249 err := storage.sendBuildAsset(bytes.NewReader(htmlContent), "cover_report.html",250 dashapi.HTMLCoverageReport, build)251 if err != nil {252 t.Fatalf("failed to upload a file: %v", err)253 }254 // Try to delete a recent file.255 dashMock.downloadURLs = map[string]bool{}256 err = storage.DeprecateAssets()257 if err != nil {258 t.Fatalf("DeprecateAssets failed: %v", err)259 } else if len(be.objects) == 0 {260 t.Fatalf("a recent object was deleted: %v", err)261 }262}263func TestAssetStorageConfiguration(t *testing.T) {264 dashMock := newDashMock()265 cfg := &Config{266 UploadTo: "dummy://",267 Assets: map[dashapi.AssetType]TypeConfig{268 dashapi.HTMLCoverageReport: {Never: true},269 dashapi.KernelObject: {},270 },271 }272 storage, err := StorageFromConfig(cfg, dashMock.getDashapi())273 if err != nil {274 t.Fatalf("unexpected error from StorageFromConfig: %s", err)275 }276 build := &dashapi.Build{ID: "1234", KernelCommit: "abcdef2134"}277 // Uploading a file of a disabled asset type.278 htmlContent := []byte("<html><head><title>Hi!</title></head></html>")279 err = storage.sendBuildAsset(bytes.NewReader(htmlContent), "cover_report.html",280 dashapi.HTMLCoverageReport, build)281 if !errors.Is(err, ErrAssetTypeDisabled) {282 t.Fatalf("UploadBuildAssetStream expected to fail with ErrAssetTypeDisabled, but got %v", err)283 }284 // Uploading a file of an unspecified asset type.285 testContent := []byte{0x1, 0x2, 0x3, 0x4}286 err = storage.sendBuildAsset(bytes.NewReader(testContent), "disk.raw", dashapi.BootableDisk, build)287 if err != nil {288 t.Fatalf("UploadBuildAssetStream of BootableDisk expected to succeed, got %v", err)289 }290 // Uploading a file of a specified asset type.291 err = storage.sendBuildAsset(bytes.NewReader(testContent), "vmlinux", dashapi.KernelObject, build)292 if err != nil {293 t.Fatalf("UploadBuildAssetStream of BootableDisk expected to succeed, got %v", err)294 }295}296func TestUploadSameContent(t *testing.T) {297 dashMock := newDashMock()298 storage, be := makeStorage(t, dashMock.getDashapi())299 be.currentTime = time.Now().Add(-2 * deletionEmbargo)300 build := &dashapi.Build{ID: "1234", KernelCommit: "abcdef2134"}301 extra := &ExtraUploadArg{UniqueTag: "uniquetag", SkipIfExists: true}302 testContent := []byte{0x1, 0x2, 0x3, 0x4}303 asset, err := storage.UploadBuildAsset(bytes.NewReader(testContent), "disk.raw",304 dashapi.BootableDisk, build, extra)305 if err != nil {306 t.Fatalf("UploadBuildAssetexpected to succeed, got %v", err)307 }308 if !strings.Contains(asset.DownloadURL, extra.UniqueTag) {309 t.Fatalf("%#v was expected to contain %#v", asset.DownloadURL, extra.UniqueTag)310 }311 // Upload the same asset again.312 be.objectUpload = func(req *uploadRequest) (*uploadResponse, error) {313 return nil, &FileExistsError{req.savePath}314 }315 assetTwo, err := storage.UploadBuildAsset(bytes.NewReader(testContent), "disk.raw",316 dashapi.BootableDisk, build, extra)317 if err != nil {318 t.Fatalf("UploadBuildAssetexpected to succeed, got %v", err)319 }320 if asset.DownloadURL != assetTwo.DownloadURL {321 t.Fatalf("assets were expected to have same download URL, got %#v %#v",322 asset.DownloadURL, assetTwo.DownloadURL)323 }324}...
storage.go
Source:storage.go
...137 }138 }139 return storage.backend.downloadURL(res.path, storage.cfg.PublicAccess)140}141func (storage *Storage) UploadBuildAsset(reader io.Reader, fileName string, assetType dashapi.AssetType,142 build *dashapi.Build, extra *ExtraUploadArg) (dashapi.NewAsset, error) {143 const commitPrefix = 8144 commit := build.KernelCommit145 if len(commit) > commitPrefix {146 commit = commit[:commitPrefix]147 }148 baseName := filepath.Base(fileName)149 fileExt := filepath.Ext(baseName)150 name := fmt.Sprintf("%s-%s%s",151 strings.TrimSuffix(baseName, fileExt),152 commit,153 fileExt)154 url, err := storage.uploadFileStream(reader, assetType, name, extra)155 if err != nil {...
UploadBuildAsset
Using AI Code Generation
1func main() {2 ctx := context.Background()3 client := github.NewClient(nil)4 f, err := os.Open("test.txt")5 if err != nil {6 }7 opt := &github.UploadOptions{8 }9 resp, err := client.Actions.UploadBuildAsset(ctx, 123, 456, opt, f)10 if err != nil {11 }12 fmt.Println(resp)13}
Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.
You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.
Get 100 minutes of automation test minutes FREE!!