Documentation ¶
Index ¶
- Constants
- Variables
- func AddMultipartFile(w *multipart.Writer, filedata []byte, filekey, filename string, ...) modules.PubfileSubfileMetadata
- func CheckBalanceVsSpending(r *TestNode, initialBalance types.Currency) error
- func CheckContractVsReportedSpending(r *TestNode, WindowSize types.BlockHeight, ...) error
- func CheckExpectedNumberOfContracts(r *TestNode, ...) error
- func CheckRenewedContractIDs(oldContracts, renewedContracts []api.RenterContract) error
- func CheckRenewedContractsSpending(renewedContracts []api.RenterContract) error
- func ChunkSize(minPieces uint64, ct crypto.CipherType) uint64
- func DrainContractsByUploading(renter *TestNode, tg *TestGroup) (startingUploadSpend types.Currency, err error)
- func FundNodes(miner *TestNode, nodes map[*TestNode]struct{}) error
- func Fuzz() int
- func Miner(dir string) node.NodeParams
- func NewGroupBuffer(size int) chan struct{}
- func PrintJSON(a interface{})
- func RenewContractsByRenewWindow(renter *TestNode, tg *TestGroup) error
- func Retry(tries int, durationBetweenAttempts time.Duration, fn func() error) (err error)
- func RunSubTests(t *testing.T, params GroupParams, directory string, tests []SubTest) error
- func TestDir(dirs ...string) string
- type GroupParams
- type LocalDir
- func (ld *LocalDir) CreateDir(name string) (*LocalDir, error)
- func (ld *LocalDir) Files() ([]*LocalFile, error)
- func (ld *LocalDir) Name() string
- func (ld *LocalDir) NewFile(size int) (*LocalFile, error)
- func (ld *LocalDir) NewFileWithMode(size int, mode os.FileMode) (*LocalFile, error)
- func (ld *LocalDir) NewFileWithName(name string, size int) (*LocalFile, error)
- func (ld *LocalDir) Path() string
- func (ld *LocalDir) PopulateDir(files, dirs, levels uint) error
- type LocalFile
- func (lf *LocalFile) Data() ([]byte, error)
- func (lf *LocalFile) Delete() error
- func (lf *LocalFile) Equal(data []byte) error
- func (lf *LocalFile) FileName() string
- func (lf *LocalFile) Move() error
- func (lf *LocalFile) Path() string
- func (lf *LocalFile) Size() int
- func (lf *LocalFile) Stat() (os.FileInfo, error)
- type RemoteDir
- type RemoteFile
- type SubTest
- type TestFile
- type TestGroup
- func (tg *TestGroup) AddNodeN(np node.NodeParams, n int) ([]*TestNode, error)
- func (tg *TestGroup) AddNodes(nps ...node.NodeParams) ([]*TestNode, error)
- func (tg *TestGroup) Close() error
- func (tg *TestGroup) Hosts() []*TestNode
- func (tg *TestGroup) Miners() []*TestNode
- func (tg *TestGroup) Nodes() []*TestNode
- func (tg *TestGroup) RemoveNode(tn *TestNode) error
- func (tg *TestGroup) Renters() []*TestNode
- func (tg *TestGroup) RestartNode(tn *TestNode) error
- func (tg *TestGroup) SetRenterAllowance(renter *TestNode, allowance modules.Allowance) error
- func (tg *TestGroup) StartNode(tn *TestNode) error
- func (tg *TestGroup) StartNodeCleanDeps(tn *TestNode) error
- func (tg *TestGroup) StopNode(tn *TestNode) error
- func (tg *TestGroup) Sync() error
- type TestNode
- func (tn *TestNode) BlockHeight() (types.BlockHeight, error)
- func (tn *TestNode) ConfirmedBalance() (types.Currency, error)
- func (tn *TestNode) ConfirmedTransactions() ([]modules.ProcessedTransaction, error)
- func (tn *TestNode) Dirs() ([]modules.SiaPath, error)
- func (tn *TestNode) DownloadByStream(rf *RemoteFile) (uid modules.DownloadID, data []byte, err error)
- func (tn *TestNode) DownloadByStreamWithDiskFetch(rf *RemoteFile, disableLocalFetch bool) (uid modules.DownloadID, data []byte, err error)
- func (tn *TestNode) DownloadDir() *LocalDir
- func (tn *TestNode) DownloadInfo(lf *LocalFile, rf *RemoteFile) (*api.DownloadInfo, error)
- func (tn *TestNode) DownloadToDisk(rf *RemoteFile, async bool) (modules.DownloadID, *LocalFile, error)
- func (tn *TestNode) DownloadToDiskPartial(rf *RemoteFile, lf *LocalFile, async bool, offset, length uint64) (modules.DownloadID, *LocalFile, error)
- func (tn *TestNode) DownloadToDiskWithDiskFetch(rf *RemoteFile, async bool, disableLocalFetch bool) (modules.DownloadID, *LocalFile, error)
- func (tn *TestNode) File(rf *RemoteFile) (fi modules.FileInfo, err error)
- func (tn *TestNode) Files(cached bool) ([]modules.FileInfo, error)
- func (tn *TestNode) FilesDir() *LocalDir
- func (tn *TestNode) IsAlertRegistered(a modules.Alert) error
- func (tn *TestNode) IsAlertUnregistered(a modules.Alert) error
- func (tn *TestNode) KnowsHost(host *TestNode) error
- func (tn *TestNode) MineBlock() error
- func (tn *TestNode) MineEmptyBlock() error
- func (tn *TestNode) NewLocalDir() (*LocalDir, error)
- func (tn *TestNode) PrintDebugInfo(t *testing.T, contractInfo, hostInfo, renterInfo bool)
- func (tn *TestNode) Rename(rf *RemoteFile, newPath modules.SiaPath) (*RemoteFile, error)
- func (tn *TestNode) RenameRoot(rf *RemoteFile, newPath modules.SiaPath, root bool) (*RemoteFile, error)
- func (tn *TestNode) RenterDir() string
- func (tn *TestNode) RenterFilesDir() string
- func (tn *TestNode) RestartNode() error
- func (tn *TestNode) SetFileRepairPath(rf *RemoteFile, lf *LocalFile) error
- func (tn *TestNode) SiaPath(path string) modules.SiaPath
- func (tn *TestNode) StartNode() error
- func (tn *TestNode) StartNodeCleanDeps() error
- func (tn *TestNode) StopNode() error
- func (tn *TestNode) Stream(rf *RemoteFile) (data []byte, err error)
- func (tn *TestNode) StreamPartial(rf *RemoteFile, lf *LocalFile, from, to uint64) (data []byte, err error)
- func (tn *TestNode) StreamWithDiskFetch(rf *RemoteFile, disableLocalFetch bool) (data []byte, err error)
- func (tn *TestNode) Upload(lf *LocalFile, siapath modules.SiaPath, dataPieces, parityPieces uint64, ...) (*RemoteFile, error)
- func (tn *TestNode) UploadBlocking(localFile *LocalFile, dataPieces uint64, parityPieces uint64, force bool) (*RemoteFile, error)
- func (tn *TestNode) UploadDirectory(ld *LocalDir) (*RemoteDir, error)
- func (tn *TestNode) UploadNewDirectory() (*RemoteDir, error)
- func (tn *TestNode) UploadNewFile(filesize int, dataPieces uint64, parityPieces uint64, force bool) (*LocalFile, *RemoteFile, error)
- func (tn *TestNode) UploadNewFileBlocking(filesize int, dataPieces uint64, parityPieces uint64, force bool) (*LocalFile, *RemoteFile, error)
- func (tn *TestNode) UploadNewMultipartSkyfileBlocking(filename string, files []TestFile, defaultPath string, disableDefaultPath bool, ...) (publink string, sup modules.SkyfileMultipartUploadParameters, ...)
- func (tn *TestNode) UploadNewSkyfileBlocking(filename string, filesize uint64, force bool) (publink string, sup modules.PubfileUploadParameters, ...)
- func (tn *TestNode) UploadNewSkyfileWithDataBlocking(filename string, filedata []byte, force bool) (publink string, sup modules.PubfileUploadParameters, ...)
- func (tn *TestNode) WaitForDecreasingRedundancy(rf *RemoteFile, redundancy float64) error
- func (tn *TestNode) WaitForDownload(lf *LocalFile, rf *RemoteFile) error
- func (tn *TestNode) WaitForFileAvailable(rf *RemoteFile) error
- func (tn *TestNode) WaitForStuckChunksToBubble() error
- func (tn *TestNode) WaitForStuckChunksToRepair() error
- func (tn *TestNode) WaitForUploadHealth(rf *RemoteFile) error
- func (tn *TestNode) WaitForUploadProgress(rf *RemoteFile, progress float64) error
Constants ¶
const ( // NumberOfParallelGroups is the number of testgroups that can be created in // parallel to prevent `too many open files` errors // // The value of 1 is based on running the siatest package with 8 threads, so // 8 tests can be run in parallel and the testgroup creation is throttled to // 1 at a time NumberOfParallelGroups = 1 )
Variables ¶
var ( // DefaultAllowance is the allowance used for the group's renters. // // Note: the default allowance needs to be close enough in practice to what // the host default settings are that price gouging protection does not kick // in. DefaultAllowance = modules.Allowance{ Funds: types.ScPrimecoinPrecision.Mul64(6), Hosts: 5, Period: 50, RenewWindow: 24, ExpectedStorage: modules.SectorSize * 256, ExpectedUpload: modules.SectorSize * 128, ExpectedDownload: modules.SectorSize * 128, ExpectedRedundancy: 5.0, MaxPeriodChurn: modules.SectorSize * 192, } )
var ( // ErrFileNotTracked is an error returned by the TestNode in case a file // wasn't accessible due to being unknown to the renter. ErrFileNotTracked = errors.New("file is not tracked by renter") )
var ( // MinerTemplate is a template for a ScPrime node that has a functioning // miner. The node has a miner and all dependencies, but no other // modules. MinerTemplate = node.NodeParams{ CreateConsensusSet: true, CreateExplorer: false, CreateGateway: true, CreateHost: false, CreateMiner: true, CreateRenter: false, CreateTransactionPool: true, CreateWallet: true, } )
var ( // SiaTestingDir is the directory that contains all of the files and // folders created during testing. SiaTestingDir = filepath.Join(os.TempDir(), "SiaTesting") )
Functions ¶
func AddMultipartFile ¶ added in v1.5.0
func AddMultipartFile(w *multipart.Writer, filedata []byte, filekey, filename string, filemode uint64, offset *uint64) modules.PubfileSubfileMetadata
AddMultipartFile is a helper function to add a file to the multipart form- data. Note that the given data will be treated as binary data, and the multi part's ContentType header will be set accordingly.
func CheckBalanceVsSpending ¶ added in v1.5.0
CheckBalanceVsSpending checks the renters confirmed siacoin balance in their wallet against their reported spending
func CheckContractVsReportedSpending ¶ added in v1.5.0
func CheckContractVsReportedSpending(r *TestNode, WindowSize types.BlockHeight, oldContracts, renewedContracts []api.RenterContract) error
CheckContractVsReportedSpending confirms that the spending recorded in the renter's contracts matches the reported spending for the renter. Renewed contracts should be the renter's active contracts and oldContracts should be the renter's inactive and expired contracts
func CheckExpectedNumberOfContracts ¶ added in v1.5.0
func CheckExpectedNumberOfContracts(r *TestNode, numActive, numPassive, numRefreshed, numDisabled, numExpired, numExpiredRefreshed int) error
CheckExpectedNumberOfContracts confirms that the renter has the expected number of each type of contract
func CheckRenewedContractIDs ¶ added in v1.5.0
func CheckRenewedContractIDs(oldContracts, renewedContracts []api.RenterContract) error
CheckRenewedContractIDs confirms that contracts are renewed as expected with hosts and no duplicate IDs
func CheckRenewedContractsSpending ¶ added in v1.5.0
func CheckRenewedContractsSpending(renewedContracts []api.RenterContract) error
CheckRenewedContractsSpending confirms that renewed contracts have zero upload and download spending. Renewed contracts should be the renter's active contracts
func ChunkSize ¶ added in v1.3.3
func ChunkSize(minPieces uint64, ct crypto.CipherType) uint64
ChunkSize is a helper method to calculate the size of a chunk depending on the minimum number of pieces required to restore the chunk.
func DrainContractsByUploading ¶ added in v1.5.0
func DrainContractsByUploading(renter *TestNode, tg *TestGroup) (startingUploadSpend types.Currency, err error)
DrainContractsByUploading uploads files until the contracts renew due to running out of funds
NOTE: in order to use this helper method the renter must use the dependency DependencyDisableUploadGougingCheck so that the uploads succeed
func FundNodes ¶ added in v1.5.0
FundNodes uses the funds of a miner node to fund all the nodes of the group
func Fuzz ¶
func Fuzz() int
Fuzz returns 0, 1 or -1. This can be used to test for random off-by-one errors in the code. For example fuzz can be used to create a File that is either sector aligned or off-by-one.
func Miner ¶
func Miner(dir string) node.NodeParams
Miner returns an MinerTemplate filled out with the provided dir.
func NewGroupBuffer ¶ added in v1.4.0
func NewGroupBuffer(size int) chan struct{}
NewGroupBuffer creates a new buffer channel and fills it
func PrintJSON ¶ added in v1.5.0
func PrintJSON(a interface{})
PrintJSON is a helper function that wraps the jsonMarshalIndent function
func RenewContractsByRenewWindow ¶ added in v1.5.0
RenewContractsByRenewWindow mines blocks to force contract renewal
func Retry ¶
Retry will call 'fn' 'tries' times, waiting 'durationBetweenAttempts' between each attempt, returning 'nil' the first time that 'fn' returns nil. If 'nil' is never returned, then the final error returned by 'fn' is returned.
func RunSubTests ¶ added in v1.5.0
RunSubTests is a helper function to run the subtests when tests can use the same test group
Types ¶
type GroupParams ¶
type GroupParams struct { Hosts int // number of hosts to create Renters int // number of renters to create Miners int // number of miners to create }
GroupParams is a helper struct to make creating TestGroups easier.
type LocalDir ¶ added in v1.4.0
type LocalDir struct {
// contains filtered or unexported fields
}
LocalDir is a helper struct that represents a directory on disk that is to be uploaded to the sia network
func (*LocalDir) CreateDir ¶ added in v1.4.0
CreateDir creates a new LocalDir in the current LocalDir with the provided name.
func (*LocalDir) NewFileWithMode ¶ added in v1.5.0
NewFileWithMode creates a new LocalFile in the current LocalDir with the given mode and size.
func (*LocalDir) NewFileWithName ¶ added in v1.5.0
NewFileWithName creates a new LocalFile in the current LocalDir with the given name and size.
func (*LocalDir) PopulateDir ¶ added in v1.4.0
PopulateDir populates a LocalDir levels deep with the number of files and directories provided at each level. The same number of files and directories will be at each level
type LocalFile ¶
type LocalFile struct {
// contains filtered or unexported fields
}
LocalFile is a helper struct that represents a file on disk that was uploaded to the ScPrime network.
func (*LocalFile) Data ¶ added in v1.5.0
Data will return the data of the file, so that it can be compared against output such as download output after it has been deleted locally.
func (*LocalFile) Equal ¶ added in v1.4.0
Equal will compare the input to the bytes of the local file, returning an error if the bytes are not a perfect match, or if there is an error reading the local file data.
type RemoteDir ¶ added in v1.4.0
type RemoteDir struct {
// contains filtered or unexported fields
}
RemoteDir is a helper struct that represents a directory on the ScPrime network.
type RemoteFile ¶
type RemoteFile struct {
// contains filtered or unexported fields
}
RemoteFile is a helper struct that represents a file uploaded to the ScPrime network.
func (*RemoteFile) Checksum ¶ added in v1.4.0
func (rf *RemoteFile) Checksum() crypto.Hash
Checksum returns the checksum of a remote file.
func (*RemoteFile) Root ¶ added in v1.5.0
func (rf *RemoteFile) Root() bool
Root returns whether the siapath needs to be treated as an absolute path.
func (*RemoteFile) SiaPath ¶ added in v1.3.4
func (rf *RemoteFile) SiaPath() modules.SiaPath
SiaPath returns the siaPath of a remote file.
type SubTest ¶ added in v1.5.0
SubTest is a helper struct for running subtests when tests can use the same test group
type TestFile ¶ added in v1.5.0
TestFile is a small helper struct that identifies a file to be uploaded. The upload helpers take a slice of these files to ensure order is maintained.
type TestGroup ¶
type TestGroup struct {
// contains filtered or unexported fields
}
TestGroup is a group of of TestNodes that are funded, synced and ready for upload, download and mining depending on their configuration
func NewGroup ¶
func NewGroup(groupDir string, nodeParams ...node.NodeParams) (*TestGroup, error)
NewGroup creates a group of TestNodes from node params. All the nodes will be connected, synced and funded. Hosts nodes are also announced.
func NewGroupFromTemplate ¶
func NewGroupFromTemplate(groupDir string, groupParams GroupParams) (*TestGroup, error)
NewGroupFromTemplate will create hosts, renters and miners according to the settings in groupParams.
func (*TestGroup) AddNodeN ¶ added in v1.3.3
AddNodeN adds n nodes of a given template to the group.
func (*TestGroup) AddNodes ¶ added in v1.3.3
func (tg *TestGroup) AddNodes(nps ...node.NodeParams) ([]*TestNode, error)
AddNodes creates a node and adds it to the group.
func (*TestGroup) Close ¶
Close closes the group and all its nodes. Closing a node is usually a slow process, but we can speed it up a lot by closing each node in a separate goroutine.
func (*TestGroup) Hosts ¶
Hosts returns all the hosts of the group. Note that the ordering of nodes in the slice returned is not the same across multiple calls this function.
func (*TestGroup) Miners ¶
Miners returns all the miners of the group. Note that the ordering of nodes in the slice returned is not the same across multiple calls this function.
func (*TestGroup) Nodes ¶
Nodes returns all the nodes of the group. Note that the ordering of nodes in the slice returned is not the same across multiple calls this function.
func (*TestGroup) RemoveNode ¶ added in v1.3.3
RemoveNode removes a node from the group and shuts it down.
func (*TestGroup) Renters ¶
Renters returns all the renters of the group. Note that the ordering of nodes in the slice returned is not the same across multiple calls this function.
func (*TestGroup) RestartNode ¶ added in v1.4.0
RestartNode stops a node and then starts it again while conducting a few checks and guaranteeing that the node is connected to the group afterwards.
func (*TestGroup) SetRenterAllowance ¶ added in v1.3.3
SetRenterAllowance finished the setup for the renter test node
func (*TestGroup) StartNode ¶ added in v1.3.3
StartNode starts a node from the group that has previously been stopped.
func (*TestGroup) StartNodeCleanDeps ¶ added in v1.5.0
StartNodeCleanDeps starts a node from the group that has previously been stopped without its previously assigned dependencies.
type TestNode ¶
TestNode is a helper struct for testing that contains a server and a client as embedded fields.
func NewCleanNode ¶
func NewCleanNode(nodeParams node.NodeParams) (*TestNode, error)
NewCleanNode creates a new TestNode that's not yet funded
func NewCleanNodeAsync ¶ added in v1.5.0
func NewCleanNodeAsync(nodeParams node.NodeParams) (*TestNode, error)
NewCleanNodeAsync creates a new TestNode that's not yet funded
func NewNode ¶
func NewNode(nodeParams node.NodeParams) (*TestNode, error)
NewNode creates a new funded TestNode
func (*TestNode) BlockHeight ¶ added in v1.4.0
func (tn *TestNode) BlockHeight() (types.BlockHeight, error)
BlockHeight returns the node's consensus modules's synced block height.
func (*TestNode) ConfirmedBalance ¶ added in v1.4.0
ConfirmedBalance returns the confirmed siacoin balance of the node's wallet.
func (*TestNode) ConfirmedTransactions ¶ added in v1.4.0
func (tn *TestNode) ConfirmedTransactions() ([]modules.ProcessedTransaction, error)
ConfirmedTransactions returns all of the wallet's tracked confirmed transactions.
func (*TestNode) Dirs ¶ added in v1.4.0
Dirs returns the siapaths of all dirs of the TestNode's renter in no deterministic order.
func (*TestNode) DownloadByStream ¶
func (tn *TestNode) DownloadByStream(rf *RemoteFile) (uid modules.DownloadID, data []byte, err error)
DownloadByStream downloads a file and returns its contents as a slice of bytes.
func (*TestNode) DownloadByStreamWithDiskFetch ¶ added in v1.5.0
func (tn *TestNode) DownloadByStreamWithDiskFetch(rf *RemoteFile, disableLocalFetch bool) (uid modules.DownloadID, data []byte, err error)
DownloadByStreamWithDiskFetch downloads a file and returns its contents as a slice of bytes.
func (*TestNode) DownloadDir ¶ added in v1.4.0
DownloadDir returns the LocalDir that is the testnodes download directory
func (*TestNode) DownloadInfo ¶
func (tn *TestNode) DownloadInfo(lf *LocalFile, rf *RemoteFile) (*api.DownloadInfo, error)
DownloadInfo returns the DownloadInfo struct of a file. If it returns nil, the download has either finished, or was never started in the first place. If the corresponding download info was found, DownloadInfo also performs a few sanity checks on its fields.
func (*TestNode) DownloadToDisk ¶
func (tn *TestNode) DownloadToDisk(rf *RemoteFile, async bool) (modules.DownloadID, *LocalFile, error)
DownloadToDisk downloads a previously uploaded file. The file will be downloaded to a random location and returned as a LocalFile object.
func (*TestNode) DownloadToDiskPartial ¶ added in v1.3.5
func (tn *TestNode) DownloadToDiskPartial(rf *RemoteFile, lf *LocalFile, async bool, offset, length uint64) (modules.DownloadID, *LocalFile, error)
DownloadToDiskPartial downloads a part of a previously uploaded file. The file will be downloaded to a random location and returned as a LocalFile object.
func (*TestNode) DownloadToDiskWithDiskFetch ¶ added in v1.5.0
func (tn *TestNode) DownloadToDiskWithDiskFetch(rf *RemoteFile, async bool, disableLocalFetch bool) (modules.DownloadID, *LocalFile, error)
DownloadToDiskWithDiskFetch downloads a previously uploaded file. The file will be downloaded to a random location and returned as a LocalFile object.
func (*TestNode) File ¶ added in v1.3.3
func (tn *TestNode) File(rf *RemoteFile) (fi modules.FileInfo, err error)
File returns the file queried by the user
func (*TestNode) FilesDir ¶ added in v1.4.0
FilesDir returns the LocalDir that is the testnodes upload directory
func (*TestNode) IsAlertRegistered ¶ added in v1.5.0
IsAlertRegistered returns an error if the given alert is not found
func (*TestNode) IsAlertUnregistered ¶ added in v1.5.0
IsAlertUnregistered returns an error if the given alert is still found
func (*TestNode) KnowsHost ¶ added in v1.3.3
KnowsHost checks if tn has a certain host in its hostdb. This check is performed using the host's public key.
func (*TestNode) MineBlock ¶
MineBlock makes the underlying node mine a single block and broadcast it.
func (*TestNode) MineEmptyBlock ¶ added in v1.5.0
MineEmptyBlock mines an empty block without any transactions and broadcasts it.
func (*TestNode) NewLocalDir ¶ added in v1.4.0
NewLocalDir creates a new LocalDir
func (*TestNode) PrintDebugInfo ¶ added in v1.3.5
PrintDebugInfo prints out helpful debug information when debug tests and ndfs, the boolean arguments dictate what is printed
func (*TestNode) Rename ¶ added in v1.4.0
func (tn *TestNode) Rename(rf *RemoteFile, newPath modules.SiaPath) (*RemoteFile, error)
Rename renames a remoteFile with the root parameter set to false and returns the new file.
func (*TestNode) RenameRoot ¶ added in v1.5.0
func (tn *TestNode) RenameRoot(rf *RemoteFile, newPath modules.SiaPath, root bool) (*RemoteFile, error)
RenameRoot renames a remoteFile with the option of setting the root parameter and returns the new file.
func (*TestNode) RenterFilesDir ¶ added in v1.4.0
RenterFilesDir returns the renter's files directory
func (*TestNode) RestartNode ¶ added in v1.3.3
RestartNode restarts a TestNode
func (*TestNode) SetFileRepairPath ¶ added in v1.3.5
func (tn *TestNode) SetFileRepairPath(rf *RemoteFile, lf *LocalFile) error
SetFileRepairPath changes the repair path of a remote file to the provided local file's path.
func (*TestNode) SiaPath ¶ added in v1.4.0
SiaPath returns the siapath of a local file or directory to be used for uploading
func (*TestNode) StartNodeCleanDeps ¶ added in v1.5.0
StartNodeCleanDeps restarts a node from an active group without its previously assigned dependencies.
func (*TestNode) Stream ¶ added in v1.3.3
func (tn *TestNode) Stream(rf *RemoteFile) (data []byte, err error)
Stream uses the streaming endpoint to download a file.
func (*TestNode) StreamPartial ¶ added in v1.3.3
func (tn *TestNode) StreamPartial(rf *RemoteFile, lf *LocalFile, from, to uint64) (data []byte, err error)
StreamPartial uses the streaming endpoint to download a partial file in range [from;to]. A local file can be provided optionally to implicitly check the checksum of the downloaded data.
func (*TestNode) StreamWithDiskFetch ¶ added in v1.5.0
func (tn *TestNode) StreamWithDiskFetch(rf *RemoteFile, disableLocalFetch bool) (data []byte, err error)
StreamWithDiskFetch uses the streaming endpoint to download a file.
func (*TestNode) Upload ¶
func (tn *TestNode) Upload(lf *LocalFile, siapath modules.SiaPath, dataPieces, parityPieces uint64, force bool) (*RemoteFile, error)
Upload uses the node to upload the file with the option to overwrite if exists.
func (*TestNode) UploadBlocking ¶ added in v1.4.0
func (tn *TestNode) UploadBlocking(localFile *LocalFile, dataPieces uint64, parityPieces uint64, force bool) (*RemoteFile, error)
UploadBlocking attempts to upload an existing file with the option to overwrite if exists and waits for the upload to reach 100% progress and full health.
func (*TestNode) UploadDirectory ¶ added in v1.4.0
UploadDirectory uses the node to upload a directory
func (*TestNode) UploadNewDirectory ¶ added in v1.4.0
UploadNewDirectory uses the node to create and upload a directory with a random name
func (*TestNode) UploadNewFile ¶
func (tn *TestNode) UploadNewFile(filesize int, dataPieces uint64, parityPieces uint64, force bool) (*LocalFile, *RemoteFile, error)
UploadNewFile initiates the upload of a filesize bytes large file with the option to overwrite if exists.
func (*TestNode) UploadNewFileBlocking ¶
func (tn *TestNode) UploadNewFileBlocking(filesize int, dataPieces uint64, parityPieces uint64, force bool) (*LocalFile, *RemoteFile, error)
UploadNewFileBlocking uploads a filesize bytes large file with the option to overwrite if exists and waits for the upload to reach 100% progress and redundancy.
func (*TestNode) UploadNewMultipartSkyfileBlocking ¶ added in v1.5.0
func (tn *TestNode) UploadNewMultipartSkyfileBlocking(filename string, files []TestFile, defaultPath string, disableDefaultPath bool, force bool) (publink string, sup modules.SkyfileMultipartUploadParameters, sshp api.SkynetSkyfileHandlerPOST, err error)
UploadNewMultipartSkyfileBlocking uploads a multipart pubfile that contains several files. After it has successfully performed the upload, it will verify the file can be downloaded using its Publink. Returns the publink, the parameters used for the upload and potentially an error. The `files` argument is a map of filepath->fileContent.
func (*TestNode) UploadNewSkyfileBlocking ¶ added in v1.5.0
func (tn *TestNode) UploadNewSkyfileBlocking(filename string, filesize uint64, force bool) (publink string, sup modules.PubfileUploadParameters, sshp api.SkynetSkyfileHandlerPOST, err error)
UploadNewSkyfileBlocking attempts to upload a pubfile of given size. After it has successfully performed the upload, it will verify the file can be downloaded using its Publink. Returns the publink, the parameters used for the upload and potentially an error.
func (*TestNode) UploadNewSkyfileWithDataBlocking ¶ added in v1.5.0
func (tn *TestNode) UploadNewSkyfileWithDataBlocking(filename string, filedata []byte, force bool) (publink string, sup modules.PubfileUploadParameters, sshp api.SkynetSkyfileHandlerPOST, err error)
UploadNewSkyfileWithDataBlocking attempts to upload a pubfile with given data. After it has successfully performed the upload, it will verify the file can be downloaded using its Publink. Returns the publink, the parameters used for the upload and potentially an error.
func (*TestNode) WaitForDecreasingRedundancy ¶ added in v1.3.3
func (tn *TestNode) WaitForDecreasingRedundancy(rf *RemoteFile, redundancy float64) error
WaitForDecreasingRedundancy waits until the redundancy decreases to a certain point.
func (*TestNode) WaitForDownload ¶
func (tn *TestNode) WaitForDownload(lf *LocalFile, rf *RemoteFile) error
WaitForDownload waits for the download of a file to finish. If a file wasn't scheduled for download it will return instantly without an error. If parent is provided, it will compare the contents of the downloaded file to the contents of tf2 after the download is finished. WaitForDownload also verifies the checksum of the downloaded file.
func (*TestNode) WaitForFileAvailable ¶ added in v1.5.0
func (tn *TestNode) WaitForFileAvailable(rf *RemoteFile) error
WaitForFileAvailable waits for a file to become available on the ScPrime network (redundancy of 1).
func (*TestNode) WaitForStuckChunksToBubble ¶ added in v1.4.0
WaitForStuckChunksToBubble waits until the stuck chunks have been bubbled to the root directory metadata
func (*TestNode) WaitForStuckChunksToRepair ¶ added in v1.4.0
WaitForStuckChunksToRepair waits until the stuck chunks have been repaired and bubbled to the root directory metadata
func (*TestNode) WaitForUploadHealth ¶ added in v1.5.0
func (tn *TestNode) WaitForUploadHealth(rf *RemoteFile) error
WaitForUploadHealth waits for a file to reach a health better than the RepairThreshold.
func (*TestNode) WaitForUploadProgress ¶
func (tn *TestNode) WaitForUploadProgress(rf *RemoteFile, progress float64) error
WaitForUploadProgress waits for a file to reach a certain upload progress.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package daemon contains tests related to the /daemon endpoints.
|
Package daemon contains tests related to the /daemon endpoints. |