package httpmock import ( "fmt" "io/ioutil" //nolint: staticcheck ) // File is a file name. The contents of this file is loaded on demand // by the following methods. // // Note that: // // file := httpmock.File("file.txt") // fmt.Printf("file: %s\n", file) // // prints the content of file "file.txt" as [File.String] method is used. // // To print the file name, and not its content, simply do: // // file := httpmock.File("file.txt") // fmt.Printf("file: %s\n", string(file)) type File string // MarshalJSON implements [encoding/json.Marshaler]. // // Useful to be used in conjunction with [NewJsonResponse] or // [NewJsonResponder] as in: // // httpmock.NewJsonResponder(200, httpmock.File("body.json")) func (f File) MarshalJSON() ([]byte, error) { return f.bytes() } func (f File) bytes() ([]byte, error) { return ioutil.ReadFile(string(f)) } // Bytes returns the content of file as a []byte. If an error occurs // during the opening or reading of the file, it panics. // // Useful to be used in conjunction with [NewBytesResponse] or // [NewBytesResponder] as in: // // httpmock.NewBytesResponder(200, httpmock.File("body.raw").Bytes()) func (f File) Bytes() []byte { b, err := f.bytes() if err != nil { panic(fmt.Sprintf("Cannot read %s: %s", string(f), err)) } return b } // String implements [fmt.Stringer] and returns the content of file as // a string. If an error occurs during the opening or reading of the // file, it panics. // // Useful to be used in conjunction with [NewStringResponse] or // [NewStringResponder] as in: // // httpmock.NewStringResponder(200, httpmock.File("body.txt").String()) func (f File) String() string { return string(f.Bytes()) }