Sha256: 7805fd67926a3b4d2179e542b75303b4368dbf37d30c208dcc12925286d80788
Contents?: true
Size: 1.67 KB
Versions: 2
Compression:
Stored size: 1.67 KB
Contents
# Test Samples ## Flat-file Data When creating testable demonstrations, there are times when sizable chunks of data are needed. It is convenient to store such data in separate files. The +Data+ method makes is easy to utilize them. Data(File.dirname(__FILE__) + '/samples/data.txt').assert =~ /dolor/ The +Data+ method can also take a block which passes the data as the blocks only argument. Data(File.dirname(__FILE__) + '/samples/data.txt') do |data| data.assert =~ /dolor/ end Files are looked-up relative to the location of the current document. If not found then they will be looked-up relative to the current working directory. ## Tabular Data The +Table+ method is similar to the +Data+ method except that it expects a YAML file, and it can take a block to iterate the data over. This makes it easy to test tables of examples. The arity of the table block corresponds to the number of columns in each row of the table. Each row is assigned in turn and run through the coded step. Consider the following example. Every row in the [table.yml table](table.yml) will be assigned to the block parameters and run through the subsequent assertion. Table File.dirname(__FILE__) + '/samples/table.yml' do |x, y| x.upcase.assert == y end Without the block, the +Table+ methods simply returns the sample data. ## Considerations Both Data and Table are some what "old fashion" approches to sample data. New techinques using plain text blocks are more convenient in that the data can be stored directly in the demonstration itself. However, for especially large data sets and external file is still the better option, and +Data+ and +Table+ make them quite easy to access.
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
qed-2.9.2 | demo/04_samples.md |
qed-2.9.1 | demo/04_samples.md |