Module: Test::Unit::Data::ClassMethods
- Defined in:
- lib/test/unit/data.rb
Defined Under Namespace
Classes: Loader
Instance Method Summary collapse
-
#data(*arguments, &block) ⇒ Object
This method provides Data-Driven-Test functionality.
-
#load_data(file_name) ⇒ Object
This method provides Data-Driven-Test functionality.
Instance Method Details
#data(label, data, options = {}) ⇒ Object #data(variable, patterns, options = {}) ⇒ Object #data(data_set, options = {}) ⇒ Object #data(options = {}, &block) ⇒ Object #data(options = {}, &block) ⇒ Object
This method provides Data-Driven-Test functionality.
Define test data in the test code.
129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 |
# File 'lib/test/unit/data.rb', line 129 def data(*arguments, &block) = nil n_arguments = arguments.size case n_arguments when 0 raise ArgumentError, "no block is given" unless block_given? data_set = block when 1 if block_given? data_set = block = arguments[1] else data_set = arguments[0] end when 2 case arguments[0] when String data_set = {arguments[0] => arguments[1]} when Hash data_set = arguments[0] = arguments[1] else variable = arguments[0] patterns = arguments[1] data_set = [variable, patterns] end when 3 case arguments[0] when String data_set = {arguments[0] => arguments[1]} = arguments[2] else variable = arguments[0] patterns = arguments[1] data_set = [variable, patterns] = arguments[2] end else = "wrong number arguments(#{n_arguments} for 0..3)" raise ArgumentError, end ||= {} data_sets = current_attribute(:data)[:value] || DataSets.new data_sets.add(data_set, ) if [:keep] keep_hook = lambda do |attr| attr.merge(value: attr[:value].keep) end = .merge(keep_hook: keep_hook) end attribute(:data, data_sets, ) end |
#load_data(file_name) ⇒ Object
This method provides Data-Driven-Test functionality.
Load test data from the file. This is shorthand to load test data from file. If you want to load complex file, you can use #data with block.
199 200 201 202 |
# File 'lib/test/unit/data.rb', line 199 def load_data(file_name) loader = Loader.new(self) loader.load(file_name) end |