rmagick 2.13.2 → 2.13.3.rc1

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of rmagick might be problematic. Click here for more details.

Files changed (185) hide show
  1. checksums.yaml +15 -0
  2. data/LICENSE +20 -0
  3. data/README +15 -0
  4. data/README.rc +231 -0
  5. data/build_tarball.rake +1 -1
  6. data/doc/comtasks.html +2 -2
  7. data/doc/constants.html +2 -2
  8. data/doc/draw.html +2 -2
  9. data/doc/ex/PreserveAspectRatio.rb +0 -0
  10. data/doc/ex/ViewBox.rb +0 -0
  11. data/doc/ex/adaptive_threshold.rb +0 -0
  12. data/doc/ex/add_noise.rb +0 -0
  13. data/doc/ex/affine.rb +0 -0
  14. data/doc/ex/affine_transform.rb +0 -0
  15. data/doc/ex/arc.rb +0 -0
  16. data/doc/ex/arcpath.rb +0 -0
  17. data/doc/ex/average.rb +0 -0
  18. data/doc/ex/axes.rb +0 -0
  19. data/doc/ex/bilevel_channel.rb +0 -0
  20. data/doc/ex/blur_image.rb +0 -0
  21. data/doc/ex/border.rb +0 -0
  22. data/doc/ex/bounding_box.rb +0 -0
  23. data/doc/ex/cbezier1.rb +0 -0
  24. data/doc/ex/cbezier2.rb +0 -0
  25. data/doc/ex/cbezier3.rb +0 -0
  26. data/doc/ex/cbezier4.rb +0 -0
  27. data/doc/ex/cbezier5.rb +0 -0
  28. data/doc/ex/cbezier6.rb +0 -0
  29. data/doc/ex/channel.rb +0 -0
  30. data/doc/ex/charcoal.rb +0 -0
  31. data/doc/ex/chop.rb +0 -0
  32. data/doc/ex/circle.rb +0 -0
  33. data/doc/ex/clip_path.rb +0 -0
  34. data/doc/ex/coalesce.rb +0 -0
  35. data/doc/ex/color_fill_to_border.rb +0 -0
  36. data/doc/ex/color_floodfill.rb +0 -0
  37. data/doc/ex/color_histogram.rb +0 -0
  38. data/doc/ex/color_reset.rb +0 -0
  39. data/doc/ex/colorize.rb +0 -0
  40. data/doc/ex/colors.rb +0 -0
  41. data/doc/ex/composite.rb +0 -0
  42. data/doc/ex/composite_layers.rb +0 -0
  43. data/doc/ex/contrast.rb +0 -0
  44. data/doc/ex/crop.rb +0 -0
  45. data/doc/ex/cycle_colormap.rb +0 -0
  46. data/doc/ex/drawcomp.rb +0 -0
  47. data/doc/ex/drop_shadow.rb +0 -0
  48. data/doc/ex/edge.rb +0 -0
  49. data/doc/ex/ellipse.rb +0 -0
  50. data/doc/ex/emboss.rb +0 -0
  51. data/doc/ex/enhance.rb +0 -0
  52. data/doc/ex/equalize.rb +0 -0
  53. data/doc/ex/evenodd.rb +0 -0
  54. data/doc/ex/flatten_images.rb +0 -0
  55. data/doc/ex/flip.rb +0 -0
  56. data/doc/ex/flop.rb +0 -0
  57. data/doc/ex/fonts.rb +0 -0
  58. data/doc/ex/frame.rb +0 -0
  59. data/doc/ex/gaussian_blur.rb +0 -0
  60. data/doc/ex/get_pixels.rb +0 -0
  61. data/doc/ex/gradientfill.rb +0 -0
  62. data/doc/ex/grav.rb +0 -0
  63. data/doc/ex/gravity.rb +0 -0
  64. data/doc/ex/hatchfill.rb +0 -0
  65. data/doc/ex/images/logo400x83.gif +0 -0
  66. data/doc/ex/implode.rb +0 -0
  67. data/doc/ex/level.rb +0 -0
  68. data/doc/ex/line.rb +0 -0
  69. data/doc/ex/matte_fill_to_border.rb +0 -0
  70. data/doc/ex/matte_floodfill.rb +0 -0
  71. data/doc/ex/matte_replace.rb +0 -0
  72. data/doc/ex/median_filter.rb +0 -0
  73. data/doc/ex/modulate.rb +0 -0
  74. data/doc/ex/mono.rb +0 -0
  75. data/doc/ex/morph.rb +0 -0
  76. data/doc/ex/mosaic.rb +0 -0
  77. data/doc/ex/motion_blur.rb +0 -0
  78. data/doc/ex/negate.rb +0 -0
  79. data/doc/ex/nested_rvg.rb +0 -0
  80. data/doc/ex/nonzero.rb +0 -0
  81. data/doc/ex/normalize.rb +0 -0
  82. data/doc/ex/oil_paint.rb +0 -0
  83. data/doc/ex/opacity.rb +0 -0
  84. data/doc/ex/ordered_dither.rb +0 -0
  85. data/doc/ex/path.rb +0 -0
  86. data/doc/ex/pattern1.rb +0 -0
  87. data/doc/ex/pattern2.rb +0 -0
  88. data/doc/ex/polygon.rb +0 -0
  89. data/doc/ex/polyline.rb +0 -0
  90. data/doc/ex/preview.rb +0 -0
  91. data/doc/ex/qbezierpath.rb +0 -0
  92. data/doc/ex/quantize-m.rb +0 -0
  93. data/doc/ex/radial_blur.rb +0 -0
  94. data/doc/ex/raise.rb +0 -0
  95. data/doc/ex/rectangle.rb +0 -0
  96. data/doc/ex/reduce_noise.rb +0 -0
  97. data/doc/ex/roll.rb +0 -0
  98. data/doc/ex/rotate.rb +0 -0
  99. data/doc/ex/rotate_f.rb +0 -0
  100. data/doc/ex/roundrect.rb +0 -0
  101. data/doc/ex/rubyname.rb +0 -0
  102. data/doc/ex/rvg_linecap.rb +0 -0
  103. data/doc/ex/rvg_linejoin.rb +0 -0
  104. data/doc/ex/rvg_opacity.rb +0 -0
  105. data/doc/ex/rvg_stroke_dasharray.rb +0 -0
  106. data/doc/ex/segment.rb +0 -0
  107. data/doc/ex/shade.rb +0 -0
  108. data/doc/ex/shave.rb +0 -0
  109. data/doc/ex/shear.rb +0 -0
  110. data/doc/ex/sketch.rb +0 -0
  111. data/doc/ex/skewx.rb +0 -0
  112. data/doc/ex/skewy.rb +0 -0
  113. data/doc/ex/smile.rb +0 -0
  114. data/doc/ex/solarize.rb +0 -0
  115. data/doc/ex/spread.rb +0 -0
  116. data/doc/ex/stegano.rb +0 -0
  117. data/doc/ex/stroke_dasharray.rb +0 -0
  118. data/doc/ex/stroke_fill.rb +0 -0
  119. data/doc/ex/stroke_linecap.rb +0 -0
  120. data/doc/ex/stroke_linejoin.rb +0 -0
  121. data/doc/ex/stroke_width.rb +0 -0
  122. data/doc/ex/swirl.rb +0 -0
  123. data/doc/ex/text.rb +0 -0
  124. data/doc/ex/text_align.rb +0 -0
  125. data/doc/ex/text_antialias.rb +0 -0
  126. data/doc/ex/text_undercolor.rb +0 -0
  127. data/doc/ex/texture_fill_to_border.rb +0 -0
  128. data/doc/ex/texture_floodfill.rb +0 -0
  129. data/doc/ex/texturefill.rb +0 -0
  130. data/doc/ex/threshold.rb +0 -0
  131. data/doc/ex/to_blob.rb +0 -0
  132. data/doc/ex/translate.rb +0 -0
  133. data/doc/ex/transparent.rb +0 -0
  134. data/doc/ex/unsharp_mask.rb +0 -0
  135. data/doc/ex/wave.rb +0 -0
  136. data/doc/ilist.html +2 -2
  137. data/doc/image1.html +2 -2
  138. data/doc/image2.html +2 -2
  139. data/doc/image3.html +2 -2
  140. data/doc/imageattrs.html +2 -2
  141. data/doc/imusage.html +2 -2
  142. data/doc/index.html +3 -3
  143. data/doc/info.html +2 -2
  144. data/doc/magick.html +2 -2
  145. data/doc/optequiv.html +2 -2
  146. data/doc/rvg.html +2 -2
  147. data/doc/rvgclip.html +2 -2
  148. data/doc/rvggroup.html +2 -2
  149. data/doc/rvgimage.html +2 -2
  150. data/doc/rvgpattern.html +2 -2
  151. data/doc/rvgshape.html +2 -2
  152. data/doc/rvgstyle.html +2 -2
  153. data/doc/rvgtext.html +2 -2
  154. data/doc/rvgtspan.html +2 -2
  155. data/doc/rvgtut.html +2 -2
  156. data/doc/rvguse.html +2 -2
  157. data/doc/rvgxform.html +2 -2
  158. data/doc/struct.html +2 -2
  159. data/doc/usage.html +2 -2
  160. data/examples/crop_with_gravity.rb +0 -0
  161. data/examples/demo.rb +0 -0
  162. data/examples/describe.rb +0 -0
  163. data/examples/rotating_text.rb +0 -0
  164. data/ext/RMagick/extconf.rb +1 -9
  165. data/ext/RMagick/rmimage.c +1 -1
  166. data/lib/rvg/to_c.rb +103 -0
  167. data/rmagick.gemspec +5 -3
  168. data/test/Draw.rb +121 -0
  169. data/test/Image1.rb +763 -0
  170. data/test/Image2.rb +1308 -0
  171. data/test/Image3.rb +1002 -0
  172. data/test/ImageList1.rb +808 -0
  173. data/test/ImageList2.rb +389 -0
  174. data/test/Image_attributes.rb +683 -0
  175. data/test/Import_Export.rb +116 -0
  176. data/test/Info.rb +349 -0
  177. data/test/Magick.rb +364 -0
  178. data/test/Pixel.rb +120 -0
  179. data/test/Preview.rb +62 -0
  180. data/test/all_basic.rb +42 -0
  181. data/test/cmyk.icm +0 -0
  182. data/test/srgb.icm +0 -0
  183. metadata +339 -320
  184. data/README.html +0 -10
  185. data/ext/RMagick/MANIFEST +0 -358
@@ -0,0 +1,389 @@
1
+
2
+ #! /usr/local/bin/ruby -w
3
+
4
+ require 'fileutils'
5
+ require 'RMagick'
6
+ require 'test/unit'
7
+ require 'test/unit/ui/console/testrunner' if !RUBY_VERSION[/^1\.9|^2/]
8
+
9
+
10
+ class ImageList2_UT < Test::Unit::TestCase
11
+
12
+ def setup
13
+ @ilist = Magick::ImageList.new
14
+ end
15
+
16
+ def test_append
17
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_0.gif')
18
+ assert_nothing_raised do
19
+ img = @ilist.append(true)
20
+ assert_instance_of(Magick::Image, img)
21
+ end
22
+ assert_nothing_raised do
23
+ img = @ilist.append(false)
24
+ assert_instance_of(Magick::Image, img)
25
+ end
26
+ assert_raise(ArgumentError) { @ilist.append }
27
+ assert_raise(ArgumentError) { @ilist.append(true, 1) }
28
+ end
29
+
30
+ def test_average
31
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_0.gif')
32
+ assert_nothing_raised do
33
+ img = @ilist.average
34
+ assert_instance_of(Magick::Image, img)
35
+ end
36
+ assert_raise(ArgumentError) { @ilist.average(1) }
37
+ end
38
+
39
+ def test_clone
40
+ @ilist.read(*Dir[IMAGES_DIR+'/Button_*.gif'])
41
+ ilist2 = @ilist.clone
42
+ assert_equal(ilist2, @ilist)
43
+ assert_equal(@ilist.frozen?, ilist2.frozen?)
44
+ assert_equal(@ilist.tainted?, ilist2.tainted?)
45
+ @ilist.taint
46
+ @ilist.freeze
47
+ ilist2 = @ilist.clone
48
+ assert_equal(@ilist.frozen?, ilist2.frozen?)
49
+ assert_equal(@ilist.tainted?, ilist2.tainted?)
50
+ end
51
+
52
+ def test_coalesce
53
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_0.gif')
54
+ ilist = nil
55
+ assert_nothing_raised { ilist = @ilist.coalesce }
56
+ assert_instance_of(Magick::ImageList, ilist)
57
+ assert_equal(2, ilist.length)
58
+ assert_equal(0, ilist.scene)
59
+ end
60
+
61
+ def test_copy
62
+ @ilist.read(*Dir[IMAGES_DIR+'/Button_*.gif'])
63
+ @ilist.scene = 7
64
+ ilist2 = @ilist.copy
65
+ assert_not_same(@ilist, ilist2)
66
+ assert_equal(@ilist.scene, ilist2.scene)
67
+ @ilist.each_with_index do |img, x|
68
+ assert_equal(img, ilist2[x])
69
+ end
70
+ end
71
+
72
+ def test_deconstruct
73
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_1.gif')
74
+ ilist = nil
75
+ assert_nothing_raised { ilist = @ilist.deconstruct }
76
+ assert_instance_of(Magick::ImageList, ilist)
77
+ assert_equal(2, ilist.length)
78
+ assert_equal(0, ilist.scene)
79
+ end
80
+
81
+ def test_dup
82
+ @ilist.read(*Dir[IMAGES_DIR+'/Button_*.gif'])
83
+ ilist2 = @ilist.dup
84
+ assert_equal(ilist2, @ilist)
85
+ assert_equal(@ilist.frozen?, ilist2.frozen?)
86
+ assert_equal(@ilist.tainted?, ilist2.tainted?)
87
+ @ilist.taint
88
+ @ilist.freeze
89
+ ilist2 = @ilist.dup
90
+ assert_not_equal(@ilist.frozen?, ilist2.frozen?)
91
+ assert_equal(@ilist.tainted?, ilist2.tainted?)
92
+ end
93
+
94
+ def flatten_images
95
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_1.gif')
96
+ assert_nothing_thrown do
97
+ img = @ilist.flatten_images
98
+ assert_instance_of(Magick::Image, img)
99
+ end
100
+ end
101
+
102
+ def test_from_blob
103
+ hat = File.open(FLOWER_HAT)
104
+ blob = hat.read
105
+ assert_nothing_raised { @ilist.from_blob(blob) }
106
+ assert_instance_of(Magick::Image, @ilist[0])
107
+ assert_equal(0, @ilist.scene)
108
+
109
+ ilist2 = Magick::ImageList.new(FLOWER_HAT)
110
+ assert_equal(@ilist, ilist2)
111
+ end
112
+
113
+ def test_fx
114
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_1.gif')
115
+ assert_nothing_raised { @ilist.fx('1/2') }
116
+ assert_nothing_raised { @ilist.fx('1/2', Magick::BlueChannel) }
117
+ assert_nothing_raised { @ilist.fx('1/2', Magick::BlueChannel, Magick::RedChannel) }
118
+ assert_raise(ArgumentError) { @ilist.fx() }
119
+ assert_raise(ArgumentError) { @ilist.fx(Magick::BlueChannel) }
120
+ assert_raise(TypeError) { @ilist.fx(1) }
121
+ assert_raise(TypeError) { @ilist.fx('1/2', 1) }
122
+ end
123
+
124
+ def test_map
125
+ map = Magick::Image.read("netscape:")[0]
126
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_1.gif')
127
+ assert_nothing_raised do
128
+ img = @ilist.map(map)
129
+ assert_instance_of(Magick::ImageList, img)
130
+ end
131
+ assert_nothing_raised do
132
+ img = @ilist.map(map, true)
133
+ assert_instance_of(Magick::ImageList, img)
134
+ end
135
+
136
+ map = Magick::ImageList.new("netscape:")
137
+ img = @ilist.map(map, true)
138
+ assert_instance_of(Magick::ImageList, img)
139
+ end
140
+
141
+ def test_marshal
142
+ ilist1 = Magick::ImageList.new(*Dir[IMAGES_DIR+'/Button_*.gif'])
143
+ d = nil
144
+ ilist2 = nil
145
+ assert_nothing_raised { d = Marshal.dump(ilist1) }
146
+ assert_nothing_raised { ilist2 = Marshal.load(d) }
147
+ assert_equal(ilist1, ilist2)
148
+ end
149
+
150
+ def test_montage
151
+ @ilist.read(*Dir[IMAGES_DIR+'/Button_*.gif'])
152
+ ilist = @ilist.copy
153
+ montage = nil
154
+ assert_nothing_thrown do
155
+ montage = ilist.montage do
156
+ self.background_color = 'black'
157
+ self.background_color = Magick::Pixel.new(Magick::QuantumRange, 0, 0)
158
+ self.border_color = 'red'
159
+ self.border_color = Magick::Pixel.new(0, 0, 0)
160
+ self.border_width = 2
161
+ self.compose = Magick::OverCompositeOp;
162
+ self.fill = 'green'
163
+ self.font = 'Arial'
164
+ self.frame = '20x20+4+4'
165
+ self.frame = Magick::Geometry.new(20, 20, 4, 4)
166
+ self.geometry = '63x60+5+5'
167
+ self.geometry = Magick::Geometry.new(63, 60, 5, 5)
168
+ self.gravity = Magick::SouthGravity
169
+ self.matte_color = '#bdbdbd'
170
+ self.pointsize = 12
171
+ self.shadow = true
172
+ self.stroke = 'transparent'
173
+ self.tile = '4x9'
174
+ self.tile = Magick::Geometry.new(4, 9)
175
+ end
176
+ assert_instance_of(Magick::ImageList, montage)
177
+ assert_equal(@ilist, ilist)
178
+ end
179
+
180
+ # test illegal option arguments
181
+ # looks like IM doesn't diagnose invalid geometry args
182
+ # to tile= and geometry=
183
+ assert_raise(TypeError) do
184
+ montage = ilist.montage { self.background_color = 2 }
185
+ assert_equal(@ilist, ilist)
186
+ end
187
+ assert_raise(TypeError) do
188
+ montage = ilist.montage { self.border_color = 2 }
189
+ assert_equal(@ilist, ilist)
190
+ end
191
+ assert_raise(TypeError) do
192
+ montage = ilist.montage { self.border_width = [2] }
193
+ assert_equal(@ilist, ilist)
194
+ end
195
+ assert_raise(TypeError) do
196
+ montage = ilist.montage { self.compose = 2 }
197
+ assert_equal(@ilist, ilist)
198
+ end
199
+ assert_raise(TypeError) do
200
+ montage = ilist.montage { self.fill = 2 }
201
+ assert_equal(@ilist, ilist)
202
+ end
203
+ assert_raise(TypeError) do
204
+ montage = ilist.montage { self.font = 2 }
205
+ assert_equal(@ilist, ilist)
206
+ end
207
+ assert_raise(Magick::ImageMagickError) do
208
+ montage = ilist.montage { self.frame = 'z' }
209
+ assert_equal(@ilist, ilist)
210
+ end
211
+ assert_raise(TypeError) do
212
+ montage = ilist.montage { self.matte_color = 2 }
213
+ assert_equal(@ilist, ilist)
214
+ end
215
+ assert_raise(TypeError) do
216
+ montage = ilist.montage { self.pointsize = 'x' }
217
+ assert_equal(@ilist, ilist)
218
+ end
219
+ assert_raise(ArgumentError) do
220
+ montage = ilist.montage { self.stroke = 'x' }
221
+ assert_equal(@ilist, ilist)
222
+ end
223
+ end
224
+
225
+ def test_morph
226
+ # can't morph an empty list
227
+ assert_raise(ArgumentError) { @ilist.morph(1) }
228
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_1.gif')
229
+ # can't specify a negative argument
230
+ assert_raise(ArgumentError) { @ilist.morph(-1) }
231
+ assert_nothing_raised do
232
+ res = @ilist.morph(2)
233
+ assert_instance_of(Magick::ImageList, res)
234
+ assert_equal(4, res.length)
235
+ assert_equal(0, res.scene)
236
+ end
237
+ end
238
+
239
+ def test_mosaic
240
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_1.gif')
241
+ assert_nothing_thrown do
242
+ res = @ilist.mosaic
243
+ assert_instance_of(Magick::Image, res)
244
+ end
245
+ end
246
+
247
+ def test_new_image
248
+ assert_nothing_raised do
249
+ @ilist.new_image(20, 20)
250
+ end
251
+ assert_equal(1, @ilist.length)
252
+ assert_equal(0, @ilist.scene)
253
+ @ilist.new_image(20, 20, Magick::HatchFill.new('black'))
254
+ assert_equal(2, @ilist.length)
255
+ assert_equal(1, @ilist.scene)
256
+ @ilist.new_image(20, 20) { self.background_color = 'red' }
257
+ assert_equal(3, @ilist.length)
258
+ assert_equal(2, @ilist.scene)
259
+ end
260
+
261
+ def test_optimize_layers
262
+ layer_methods = [
263
+ Magick::CompareAnyLayer,
264
+ Magick::CompareClearLayer,
265
+ Magick::CompareOverlayLayer,
266
+ Magick::OptimizeLayer,
267
+ Magick::OptimizePlusLayer,
268
+ Magick::CoalesceLayer,
269
+ Magick::DisposeLayer,
270
+ Magick::OptimizeTransLayer,
271
+ Magick::RemoveDupsLayer,
272
+ Magick::RemoveZeroLayer
273
+ ]
274
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_1.gif')
275
+ layer_methods.each do |method|
276
+ assert_nothing_raised do
277
+ res = @ilist.optimize_layers(method)
278
+ assert_instance_of(Magick::ImageList, res)
279
+ assert_equal(2, res.length)
280
+ end
281
+ end
282
+ assert_raise(ArgumentError) {@ilist.optimize_layers(Magick::UndefinedLayer)}
283
+ assert_raise(TypeError) {@ilist.optimize_layers(2)}
284
+ end
285
+
286
+ def test_ping
287
+ assert_nothing_raised { @ilist.ping(FLOWER_HAT) }
288
+ assert_equal(1, @ilist.length)
289
+ assert_equal(0, @ilist.scene)
290
+ assert_nothing_raised { @ilist.ping(FLOWER_HAT, FLOWER_HAT) }
291
+ assert_equal(3, @ilist.length)
292
+ assert_equal(2, @ilist.scene)
293
+ assert_nothing_raised { @ilist.ping(FLOWER_HAT) { self.background_color = 'red ' } }
294
+ assert_equal(4, @ilist.length)
295
+ assert_equal(3, @ilist.scene)
296
+ end
297
+
298
+ def test_quantize
299
+ @ilist.read(IMAGES_DIR+'/Button_0.gif', IMAGES_DIR+'/Button_1.gif')
300
+ assert_nothing_raised do
301
+ res = @ilist.quantize
302
+ assert_instance_of(Magick::ImageList, res)
303
+ assert_equal(1, res.scene)
304
+ end
305
+ assert_nothing_raised { @ilist.quantize(128) }
306
+ assert_raise(TypeError) { @ilist.quantize('x') }
307
+ assert_nothing_raised { @ilist.quantize(128, Magick::RGBColorspace) }
308
+ assert_raise(TypeError) { @ilist.quantize(128, 'x') }
309
+ assert_nothing_raised { @ilist.quantize(128, Magick::RGBColorspace, true, 0) }
310
+ assert_nothing_raised { @ilist.quantize(128, Magick::RGBColorspace, true) }
311
+ assert_nothing_raised { @ilist.quantize(128, Magick::RGBColorspace, false) }
312
+ assert_nothing_raised { @ilist.quantize(128, Magick::RGBColorspace, Magick::NoDitherMethod) }
313
+ assert_nothing_raised { @ilist.quantize(128, Magick::RGBColorspace, Magick::RiemersmaDitherMethod) }
314
+ assert_nothing_raised { @ilist.quantize(128, Magick::RGBColorspace, Magick::FloydSteinbergDitherMethod) }
315
+ assert_raise(TypeError) { @ilist.quantize(128, Magick::RGBColorspace, true, 'x' ) }
316
+ assert_raise(ArgumentError) { @ilist.quantize(128, Magick::RGBColorspace, true, 0, false, 'extra') }
317
+ end
318
+
319
+ def test_read
320
+ assert_nothing_raised { @ilist.read(FLOWER_HAT) }
321
+ assert_equal(1, @ilist.length)
322
+ assert_equal(0, @ilist.scene)
323
+ assert_nothing_raised { @ilist.read(FLOWER_HAT, FLOWER_HAT) }
324
+ assert_equal(3, @ilist.length)
325
+ assert_equal(2, @ilist.scene)
326
+ assert_nothing_raised { @ilist.read(FLOWER_HAT) { self.background_color = 'red ' } }
327
+ assert_equal(4, @ilist.length)
328
+ assert_equal(3, @ilist.scene)
329
+ end
330
+
331
+ def test_remap
332
+ @ilist.read(*Dir[IMAGES_DIR+'/Button_*.gif'])
333
+ assert_nothing_raised { @ilist.remap }
334
+ remap_image = Magick::Image.new(20,20) {self.background_color = "green"}
335
+ assert_nothing_raised { @ilist.remap(remap_image) }
336
+ assert_nothing_raised { @ilist.remap(remap_image, Magick::NoDitherMethod) }
337
+ assert_nothing_raised { @ilist.remap(remap_image, Magick::RiemersmaDitherMethod) }
338
+ assert_nothing_raised { @ilist.remap(remap_image, Magick::FloydSteinbergDitherMethod) }
339
+ assert_raise(ArgumentError) { @ilist.remap(remap_image, Magick::NoDitherMethod, 1) }
340
+
341
+ remap_image.destroy!
342
+ assert_raise(Magick::DestroyedImageError) { @ilist.remap(remap_image) }
343
+ #assert_raise(TypeError) { @ilist.affinity(affinity_image, 1) }
344
+ end
345
+
346
+ def test_to_blob
347
+ @ilist.read(IMAGES_DIR+'/Button_0.gif')
348
+ blob = nil
349
+ assert_nothing_raised { blob = @ilist.to_blob }
350
+ img = @ilist.from_blob(blob)
351
+ assert_equal(@ilist[0], img[0])
352
+ assert_equal(1, img.scene)
353
+ end
354
+
355
+ def test_write
356
+ @ilist.read(IMAGES_DIR+'/Button_0.gif')
357
+ assert_nothing_raised do
358
+ @ilist.write('temp.gif')
359
+ end
360
+ list = Magick::ImageList.new('temp.gif')
361
+ assert_equal('GIF', list.format)
362
+ FileUtils.rm('temp.gif')
363
+
364
+ @ilist.write("jpg:temp.foo")
365
+ list = Magick::ImageList.new('temp.foo')
366
+ assert_equal('JPEG', list.format)
367
+ FileUtils.rm('temp.foo')
368
+
369
+ @ilist.write("temp.0") { self.format = "JPEG" }
370
+ list = Magick::ImageList.new('temp.0')
371
+ assert_equal("JPEG", list.format)
372
+ FileUtils.rm('temp.0')
373
+
374
+ f = File.new("test.0", "w")
375
+ @ilist.write(f) { self.format = "JPEG" }
376
+ f.close
377
+ list = Magick::ImageList.new('test.0')
378
+ assert_equal("JPEG", list.format)
379
+ FileUtils.rm('test.0')
380
+ end
381
+
382
+ end
383
+
384
+
385
+ if __FILE__ == $0
386
+ IMAGES_DIR = '../doc/ex/images'
387
+ FLOWER_HAT = IMAGES_DIR+'/Flower_Hat.jpg'
388
+ Test::Unit::UI::Console::TestRunner.run(ImageList2_UT) if !RUBY_VERSION[/^1\.9|^2/]
389
+ end
@@ -0,0 +1,683 @@
1
+ #! /usr/local/bin/ruby -w
2
+
3
+ require 'fileutils'
4
+ require 'RMagick'
5
+ require 'test/unit'
6
+ require 'test/unit/ui/console/testrunner' if !RUBY_VERSION[/^1\.9|^2/]
7
+
8
+ # TODO
9
+ # test frozen attributes!
10
+ # improve test_directory
11
+ # improve test_montage
12
+
13
+
14
+ class Image_Attributes_UT < Test::Unit::TestCase
15
+ FreezeError = RUBY_VERSION[/^1\.9|^2/] ? RuntimeError : TypeError
16
+
17
+ def setup
18
+ @img = Magick::Image.new(100, 100)
19
+ gc = Magick::Draw.new
20
+
21
+ gc.stroke_width(5)
22
+ gc.circle(50, 50, 80, 80)
23
+ gc.draw(@img)
24
+
25
+ @hat = Magick::Image.read(FLOWER_HAT).first
26
+ @p = Magick::Image.read(IMAGE_WITH_PROFILE).first.color_profile
27
+ end
28
+
29
+ # Test old alpha attribute. New alpha() behavior is tested in Image1.rb
30
+ def test_alpha
31
+ assert(@img.alpha)
32
+ assert_nothing_raised { @img.alpha = Magick::DeactivateAlphaChannel }
33
+ assert(!@img.alpha)
34
+ end
35
+
36
+ def test_background_color
37
+ assert_nothing_raised { @img.background_color }
38
+ assert_equal("white", @img.background_color)
39
+ assert_nothing_raised { @img.background_color = "#dfdfdf" }
40
+ #assert_equal("rgb(223,223,223)", @img.background_color)
41
+ assert_equal("#DFDFDFDFDFDF", @img.background_color)
42
+ assert_nothing_raised { @img.background_color = Magick::Pixel.new(Magick::QuantumRange, Magick::QuantumRange/2.0, Magick::QuantumRange/2.0) }
43
+ #assert_equal("rgb(100%,49.9992%,49.9992%)", @img.background_color)
44
+ assert_equal("#FFFF7FFF7FFF", @img.background_color)
45
+ assert_raise(TypeError) { @img.background_color = 2 }
46
+ end
47
+
48
+ def test_base_columns
49
+ assert_nothing_raised { @img.base_columns }
50
+ assert_equal(0, @img.base_columns)
51
+ assert_raise(NoMethodError) { @img.base_columns = 1 }
52
+ end
53
+
54
+ def test_base_filename
55
+ assert_nothing_raised { @img.base_filename }
56
+ assert_equal("", @img.base_filename)
57
+ assert_raise(NoMethodError) { @img.base_filename = "xxx" }
58
+ end
59
+
60
+ def test_base_rows
61
+ assert_nothing_raised { @img.base_rows }
62
+ assert_equal(0, @img.base_rows)
63
+ assert_raise(NoMethodError) { @img.base_rows = 1 }
64
+ end
65
+
66
+ def test_bias
67
+ assert_nothing_raised { @img.bias }
68
+ assert_equal(0.0, @img.bias)
69
+ assert_instance_of(Float, @img.bias)
70
+
71
+ assert_nothing_raised { @img.bias = 0.1 }
72
+ assert_in_delta(Magick::QuantumRange * 0.1, @img.bias, 0.1)
73
+
74
+ assert_nothing_raised { @img.bias = '10%' }
75
+ assert_in_delta(Magick::QuantumRange * 0.10, @img.bias, 0.1)
76
+
77
+ assert_raise(TypeError) { @img.bias = [] }
78
+ assert_raise(ArgumentError) { @img.bias = 'x' }
79
+ end
80
+
81
+ def test_black_point_compensation
82
+ assert_nothing_raised { @img.black_point_compensation = true }
83
+ assert(@img.black_point_compensation)
84
+ assert_nothing_raised { @img.black_point_compensation = false }
85
+ assert_equal(false, @img.black_point_compensation)
86
+ end
87
+
88
+ def test_blur
89
+ assert_nothing_raised { @img.blur }
90
+ assert_equal(1.0, @img.blur)
91
+ assert_nothing_raised { @img.blur = 2.0 }
92
+ assert_raise(TypeError) { @img.blur = 'x' }
93
+ end
94
+
95
+ def test_border_color
96
+ assert_nothing_raised { @img.border_color }
97
+ #assert_equal("rgb(223,223,223)", @img.border_color)
98
+ assert_equal("#DFDFDFDFDFDF", @img.border_color)
99
+ assert_nothing_raised { @img.border_color = "red" }
100
+ assert_equal("red", @img.border_color)
101
+ assert_nothing_raised { @img.border_color = Magick::Pixel.new(Magick::QuantumRange, Magick::QuantumRange/2, Magick::QuantumRange/2) }
102
+ #assert_equal("rgb(100%,49.9992%,49.9992%)", @img.border_color)
103
+ assert_equal("#FFFF7FFF7FFF", @img.border_color)
104
+ assert_raise(TypeError) { @img.border_color = 2 }
105
+ end
106
+
107
+ def test_bounding_box
108
+ assert_nothing_raised { @img.bounding_box }
109
+ box = @img.bounding_box
110
+ assert_equal(87, box.width)
111
+ assert_equal(87, box.height)
112
+ assert_equal(7, box.x)
113
+ assert_equal(7, box.y)
114
+ assert_raise(NoMethodError) { @img.bounding_box = 2 }
115
+ end
116
+
117
+ def test_chromaticity
118
+ chrom = @img.chromaticity
119
+ assert_nothing_raised { @img.chromaticity }
120
+ assert_instance_of(Magick::Chromaticity, chrom)
121
+ assert_equal(0, chrom.red_primary.x)
122
+ assert_equal(0, chrom.red_primary.y)
123
+ assert_equal(0, chrom.red_primary.z)
124
+ assert_equal(0, chrom.green_primary.x)
125
+ assert_equal(0, chrom.green_primary.y)
126
+ assert_equal(0, chrom.green_primary.z)
127
+ assert_equal(0, chrom.blue_primary.x)
128
+ assert_equal(0, chrom.blue_primary.y)
129
+ assert_equal(0, chrom.blue_primary.z)
130
+ assert_equal(0, chrom.white_point.x)
131
+ assert_equal(0, chrom.white_point.y)
132
+ assert_equal(0, chrom.white_point.z)
133
+ assert_nothing_raised { @img.chromaticity = chrom }
134
+ assert_raise(TypeError) { @img.chromaticity = 2 }
135
+ end
136
+
137
+ def test_class_type
138
+ assert_nothing_raised { @img.class_type }
139
+ assert_instance_of(Magick::ClassType, @img.class_type)
140
+ assert_equal(Magick::DirectClass, @img.class_type)
141
+ assert_nothing_raised { @img.class_type = Magick::PseudoClass }
142
+ assert_equal(Magick::PseudoClass, @img.class_type)
143
+ assert_raise(TypeError) { @img.class_type = 2 }
144
+ end
145
+
146
+ def test_color_profile
147
+ assert_nothing_raised { @img.color_profile }
148
+ assert_nil(@img.color_profile)
149
+ assert_nothing_raised { @img.color_profile = @p }
150
+ assert_equal(@p, @img.color_profile)
151
+ assert_raise(TypeError) { @img.color_profile = 2 }
152
+ end
153
+
154
+ def test_colors
155
+ assert_nothing_raised { @img.colors }
156
+ assert_equal(0, @img.colors)
157
+ img = @img.copy
158
+ img.class_type = Magick::PseudoClass
159
+ assert_equal(40, img.colors)
160
+ assert_raise(NoMethodError) { img.colors = 2 }
161
+ end
162
+
163
+ def test_colorspace
164
+ assert_nothing_raised { @img.colorspace }
165
+ assert_instance_of(Magick::ColorspaceType, @img.colorspace)
166
+ assert_equal(Magick::RGBColorspace, @img.colorspace)
167
+ img = @img.copy
168
+ assert_nothing_raised { img.colorspace = Magick::GRAYColorspace }
169
+ assert_equal(Magick::GRAYColorspace, img.colorspace)
170
+ assert_raise(TypeError) { @img.colorspace = 2 }
171
+ Magick::ColorspaceType.values.each do |cs|
172
+ assert_nothing_raised { img.colorspace = cs }
173
+ end
174
+ end
175
+
176
+ def test_columns
177
+ assert_nothing_raised { @img.columns }
178
+ assert_equal(100, @img.columns)
179
+ assert_raise(NoMethodError) { @img.columns = 2 }
180
+ end
181
+
182
+ def test_compose
183
+ assert_nothing_raised { @img.compose }
184
+ assert_instance_of(Magick::CompositeOperator, @img.compose)
185
+ assert_equal(Magick::OverCompositeOp, @img.compose)
186
+ assert_raise(TypeError) { @img.compose = 2 }
187
+ assert_nothing_raised { @img.compose = Magick::UndefinedCompositeOp }
188
+ assert_equal(Magick::UndefinedCompositeOp, @img.compose)
189
+
190
+ assert_nothing_raised { @img.compose = Magick::NoCompositeOp }
191
+ assert_nothing_raised { @img.compose = Magick::AddCompositeOp }
192
+ assert_nothing_raised { @img.compose = Magick::AtopCompositeOp }
193
+ assert_nothing_raised { @img.compose = Magick::BlendCompositeOp }
194
+ assert_nothing_raised { @img.compose = Magick::BumpmapCompositeOp }
195
+ assert_nothing_raised { @img.compose = Magick::ClearCompositeOp }
196
+ assert_nothing_raised { @img.compose = Magick::ColorBurnCompositeOp }
197
+ assert_nothing_raised { @img.compose = Magick::ColorDodgeCompositeOp }
198
+ assert_nothing_raised { @img.compose = Magick::ColorizeCompositeOp }
199
+ assert_nothing_raised { @img.compose = Magick::CopyBlackCompositeOp }
200
+ assert_nothing_raised { @img.compose = Magick::CopyBlueCompositeOp }
201
+ assert_nothing_raised { @img.compose = Magick::CopyCompositeOp }
202
+ assert_nothing_raised { @img.compose = Magick::CopyCyanCompositeOp }
203
+ assert_nothing_raised { @img.compose = Magick::CopyGreenCompositeOp }
204
+ assert_nothing_raised { @img.compose = Magick::CopyMagentaCompositeOp }
205
+ assert_nothing_raised { @img.compose = Magick::CopyOpacityCompositeOp }
206
+ assert_nothing_raised { @img.compose = Magick::CopyRedCompositeOp }
207
+ assert_nothing_raised { @img.compose = Magick::CopyYellowCompositeOp }
208
+ assert_nothing_raised { @img.compose = Magick::DarkenCompositeOp }
209
+ assert_nothing_raised { @img.compose = Magick::DstAtopCompositeOp }
210
+ assert_nothing_raised { @img.compose = Magick::DstCompositeOp }
211
+ assert_nothing_raised { @img.compose = Magick::DstInCompositeOp }
212
+ assert_nothing_raised { @img.compose = Magick::DstOutCompositeOp }
213
+ assert_nothing_raised { @img.compose = Magick::DstOverCompositeOp }
214
+ assert_nothing_raised { @img.compose = Magick::DifferenceCompositeOp }
215
+ assert_nothing_raised { @img.compose = Magick::DisplaceCompositeOp }
216
+ assert_nothing_raised { @img.compose = Magick::DissolveCompositeOp }
217
+ assert_nothing_raised { @img.compose = Magick::ExclusionCompositeOp }
218
+ assert_nothing_raised { @img.compose = Magick::HardLightCompositeOp }
219
+ assert_nothing_raised { @img.compose = Magick::HueCompositeOp }
220
+ assert_nothing_raised { @img.compose = Magick::InCompositeOp }
221
+ assert_nothing_raised { @img.compose = Magick::LightenCompositeOp }
222
+ assert_nothing_raised { @img.compose = Magick::LuminizeCompositeOp }
223
+ assert_nothing_raised { @img.compose = Magick::MinusCompositeOp }
224
+ assert_nothing_raised { @img.compose = Magick::ModulateCompositeOp }
225
+ assert_nothing_raised { @img.compose = Magick::MultiplyCompositeOp }
226
+ assert_nothing_raised { @img.compose = Magick::OutCompositeOp }
227
+ assert_nothing_raised { @img.compose = Magick::OverCompositeOp }
228
+ assert_nothing_raised { @img.compose = Magick::OverlayCompositeOp }
229
+ assert_nothing_raised { @img.compose = Magick::PlusCompositeOp }
230
+ assert_nothing_raised { @img.compose = Magick::ReplaceCompositeOp }
231
+ assert_nothing_raised { @img.compose = Magick::SaturateCompositeOp }
232
+ assert_nothing_raised { @img.compose = Magick::ScreenCompositeOp }
233
+ assert_nothing_raised { @img.compose = Magick::SoftLightCompositeOp }
234
+ assert_nothing_raised { @img.compose = Magick::SrcAtopCompositeOp }
235
+ assert_nothing_raised { @img.compose = Magick::SrcCompositeOp }
236
+ assert_nothing_raised { @img.compose = Magick::SrcInCompositeOp }
237
+ assert_nothing_raised { @img.compose = Magick::SrcOutCompositeOp }
238
+ assert_nothing_raised { @img.compose = Magick::SrcOverCompositeOp }
239
+ assert_nothing_raised { @img.compose = Magick::SubtractCompositeOp }
240
+ assert_nothing_raised { @img.compose = Magick::ThresholdCompositeOp }
241
+ assert_nothing_raised { @img.compose = Magick::XorCompositeOp }
242
+ assert_raise(TypeError) { @img.compose = 2 }
243
+ end
244
+
245
+ def test_compression
246
+ assert_nothing_raised { @img.compression }
247
+ assert_instance_of(Magick::CompressionType, @img.compression)
248
+ assert_equal(Magick::UndefinedCompression, @img.compression)
249
+ assert_nothing_raised { @img.compression = Magick::BZipCompression }
250
+ assert_equal(Magick::BZipCompression, @img.compression)
251
+ assert_nothing_raised { @img.compression = Magick::NoCompression }
252
+ assert_nothing_raised { @img.compression = Magick::BZipCompression }
253
+ assert_nothing_raised { @img.compression = Magick::B44Compression }
254
+ assert_nothing_raised { @img.compression = Magick::B44ACompression }
255
+ assert_nothing_raised { @img.compression = Magick::DXT1Compression }
256
+ assert_nothing_raised { @img.compression = Magick::DXT3Compression }
257
+ assert_nothing_raised { @img.compression = Magick::DXT5Compression }
258
+ assert_nothing_raised { @img.compression = Magick::FaxCompression }
259
+ assert_nothing_raised { @img.compression = Magick::Group4Compression }
260
+ assert_nothing_raised { @img.compression = Magick::JPEGCompression }
261
+ assert_nothing_raised { @img.compression = Magick::JPEG2000Compression }
262
+ assert_nothing_raised { @img.compression = Magick::LosslessJPEGCompression }
263
+ assert_nothing_raised { @img.compression = Magick::LZWCompression }
264
+ assert_nothing_raised { @img.compression = Magick::PizCompression }
265
+ assert_nothing_raised { @img.compression = Magick::Pxr24Compression }
266
+ assert_nothing_raised { @img.compression = Magick::RLECompression }
267
+ assert_nothing_raised { @img.compression = Magick::ZipCompression }
268
+ assert_nothing_raised { @img.compression = Magick::ZipSCompression }
269
+ assert_raise(TypeError) { @img.compression = 2 }
270
+ end
271
+
272
+ def test_delay
273
+ assert_nothing_raised { @img.delay }
274
+ assert_equal(0, @img.delay)
275
+ assert_nothing_raised { @img.delay = 10 }
276
+ assert_equal(10, @img.delay)
277
+ assert_raise(TypeError) { @img.delay = 'x' }
278
+ end
279
+
280
+ def test_density
281
+ assert_nothing_raised { @img.density }
282
+ assert_equal('72x72', @img.density)
283
+ assert_nothing_raised { @img.density = '90x90' }
284
+ assert_nothing_raised { @img.density = 'x90' }
285
+ assert_nothing_raised { @img.density = '90' }
286
+ assert_raise(TypeError) { @img.density = 2 }
287
+ end
288
+
289
+ def test_depth
290
+ assert_equal(Magick::QuantumDepth, @img.depth)
291
+ assert_raise(NoMethodError) { @img.depth = 2 }
292
+ end
293
+
294
+ def test_directory
295
+ assert_nothing_raised { @img.directory }
296
+ assert_nil(@img.directory)
297
+ assert_raise(NoMethodError) { @img.directory = nil }
298
+ end
299
+
300
+ def test_dispose
301
+ assert_nothing_raised { @img.dispose }
302
+ assert_instance_of(Magick::DisposeType, @img.dispose)
303
+ assert_equal(Magick::UndefinedDispose, @img.dispose)
304
+ assert_nothing_raised { @img.dispose = Magick::NoneDispose }
305
+ assert_equal(Magick::NoneDispose, @img.dispose)
306
+ assert_nothing_raised { @img.dispose = Magick::BackgroundDispose }
307
+ assert_nothing_raised { @img.dispose = Magick::PreviousDispose }
308
+ assert_raise(TypeError) { @img.dispose = 2 }
309
+ end
310
+
311
+ def test_endian
312
+ assert_nothing_raised { @img.endian }
313
+ assert_instance_of(Magick::EndianType, @img.endian)
314
+ assert_equal(Magick::UndefinedEndian, @img.endian)
315
+ assert_nothing_raised { @img.endian = Magick::LSBEndian }
316
+ assert_equal(Magick::LSBEndian, @img.endian)
317
+ assert_nothing_raised { @img.endian = Magick::MSBEndian }
318
+ assert_raise(TypeError) { @img.endian = 2 }
319
+ end
320
+
321
+ def test_extract_info
322
+ assert_nothing_raised { @img.extract_info }
323
+ assert_instance_of(Magick::Rectangle, @img.extract_info)
324
+ ext = @img.extract_info
325
+ assert_equal(0, ext.x)
326
+ assert_equal(0, ext.y)
327
+ assert_equal(0, ext.width)
328
+ assert_equal(0, ext.height)
329
+ ext = Magick::Rectangle.new(1, 2, 3, 4)
330
+ assert_nothing_raised { @img.extract_info = ext }
331
+ assert_equal(1, ext.width)
332
+ assert_equal(2, ext.height)
333
+ assert_equal(3, ext.x)
334
+ assert_equal(4, ext.y)
335
+ assert_raise(TypeError) { @img.extract_info = 2 }
336
+ end
337
+
338
+ def test_filename
339
+ assert_nothing_raised { @img.filename }
340
+ assert_equal("", @img.filename)
341
+ assert_raises(NoMethodError) { @img.filename = 'xxx' }
342
+ end
343
+
344
+ def test_filter
345
+ assert_nothing_raised { @img.filter }
346
+ assert_instance_of(Magick::FilterTypes, @img.filter)
347
+ assert_equal(Magick::UndefinedFilter, @img.filter)
348
+ assert_nothing_raised { @img.filter = Magick::PointFilter }
349
+ assert_equal(Magick::PointFilter, @img.filter)
350
+ assert_nothing_raised { @img.filter = Magick::BoxFilter }
351
+ assert_nothing_raised { @img.filter = Magick::TriangleFilter }
352
+ assert_nothing_raised { @img.filter = Magick::HermiteFilter }
353
+ assert_nothing_raised { @img.filter = Magick::HanningFilter }
354
+ assert_nothing_raised { @img.filter = Magick::HammingFilter }
355
+ assert_nothing_raised { @img.filter = Magick::BlackmanFilter }
356
+ assert_nothing_raised { @img.filter = Magick::GaussianFilter }
357
+ assert_nothing_raised { @img.filter = Magick::QuadraticFilter }
358
+ assert_nothing_raised { @img.filter = Magick::CubicFilter }
359
+ assert_nothing_raised { @img.filter = Magick::CatromFilter }
360
+ assert_nothing_raised { @img.filter = Magick::MitchellFilter }
361
+ assert_nothing_raised { @img.filter = Magick::LanczosFilter }
362
+ assert_nothing_raised { @img.filter = Magick::BesselFilter }
363
+ assert_nothing_raised { @img.filter = Magick::SincFilter }
364
+ assert_raise(TypeError) { @img.filter = 2 }
365
+ end
366
+
367
+ def test_format
368
+ assert_nothing_raised { @img.format }
369
+ assert_nil(@img.format)
370
+ assert_nothing_raised { @img.format = 'GIF' }
371
+ assert_nothing_raised { @img.format = 'JPG' }
372
+ assert_nothing_raised { @img.format = 'TIFF' }
373
+ assert_nothing_raised { @img.format = 'MIFF' }
374
+ assert_nothing_raised { @img.format = 'MPEG' }
375
+ v = $VERBOSE
376
+ $VERBOSE = nil
377
+ assert_raise(ArgumentError) { @img.format = 'shit' }
378
+ $VERBOSE = v
379
+ assert_raise(TypeError) { @img.format = 2 }
380
+ end
381
+
382
+ def test_fuzz
383
+ assert_nothing_raised { @img.fuzz }
384
+ assert_instance_of(Float, @img.fuzz)
385
+ assert_equal(0.0, @img.fuzz)
386
+ assert_nothing_raised { @img.fuzz = 50 }
387
+ assert_equal(50.0, @img.fuzz)
388
+ assert_nothing_raised { @img.fuzz = '50%' }
389
+ assert_in_delta(Magick::QuantumRange * 0.50, @img.fuzz, 0.1)
390
+ assert_raise(TypeError) { @img.fuzz = [] }
391
+ assert_raise(ArgumentError) { @img.fuzz = 'xxx' }
392
+ end
393
+
394
+ def test_gamma
395
+ assert_nothing_raised { @img.gamma }
396
+ assert_instance_of(Float, @img.gamma)
397
+ assert_equal(0.0, @img.gamma)
398
+ assert_nothing_raised { @img.gamma = 2.0 }
399
+ assert_equal(2.0, @img.gamma)
400
+ assert_raise(TypeError) { @img.gamma = 'x' }
401
+ end
402
+
403
+ def test_geometry
404
+ assert_nothing_raised { @img.geometry }
405
+ assert_nil(@img.geometry)
406
+ assert_nothing_raised { @img.geometry = '90x90' }
407
+ assert_equal('90x90', @img.geometry)
408
+ assert_nothing_raised { @img.geometry = Magick::Geometry.new(100, 80) }
409
+ assert_equal('100x80', @img.geometry)
410
+ assert_raise(TypeError) { @img.geometry = [] }
411
+ end
412
+
413
+ def test_image_type
414
+ assert_nothing_raised { @img.image_type }
415
+ assert_instance_of(Magick::ImageType, @img.image_type)
416
+ assert_equal(Magick::GrayscaleMatteType, @img.image_type)
417
+ end
418
+
419
+ def test_interlace_type
420
+ assert_nothing_raised { @img.interlace }
421
+ assert_instance_of(Magick::InterlaceType, @img.interlace)
422
+ assert_equal(Magick::NoInterlace, @img.interlace)
423
+ assert_nothing_raised { @img.interlace = Magick::LineInterlace }
424
+ assert_equal(Magick::LineInterlace, @img.interlace)
425
+ assert_nothing_raised { @img.interlace = Magick::PlaneInterlace }
426
+ assert_nothing_raised { @img.interlace = Magick::PartitionInterlace }
427
+ assert_raise(TypeError) { @img.interlace = 2 }
428
+ end
429
+
430
+ def test_iptc_profile
431
+ assert_nothing_raised { @img.iptc_profile }
432
+ assert_nil(@img.iptc_profile)
433
+ assert_nothing_raised { @img.iptc_profile = 'xxx' }
434
+ assert_raise(TypeError) { @img.iptc_profile = 2 }
435
+ end
436
+
437
+ def test_matte
438
+ assert_nothing_raised { @img.matte }
439
+ assert(@img.matte)
440
+ assert_nothing_raised { @img.matte = false }
441
+ assert(!@img.matte)
442
+ end
443
+
444
+ def test_mean_error
445
+ assert_nothing_raised { @hat.mean_error_per_pixel }
446
+ assert_nothing_raised { @hat.normalized_mean_error }
447
+ assert_nothing_raised { @hat.normalized_maximum_error }
448
+ assert_equal(0.0, @hat.mean_error_per_pixel)
449
+ assert_equal(0.0, @hat.normalized_mean_error)
450
+ assert_equal(0.0, @hat.normalized_maximum_error)
451
+
452
+ hat = @hat.quantize(16, Magick::RGBColorspace, true, 0, true)
453
+
454
+ assert_not_equal(0.0, hat.mean_error_per_pixel)
455
+ assert_not_equal(0.0, hat.normalized_mean_error)
456
+ assert_not_equal(0.0, hat.normalized_maximum_error)
457
+ assert_raise(NoMethodError) { hat.mean_error_per_pixel = 1 }
458
+ assert_raise(NoMethodError) { hat.normalized_mean_error = 1 }
459
+ assert_raise(NoMethodError) { hat.normalized_maximum_error = 1 }
460
+ end
461
+
462
+ def test_mime_type
463
+ img = @img.copy
464
+ img.format = 'GIF'
465
+ assert_nothing_raised { img.mime_type }
466
+ assert_equal('image/gif', img.mime_type)
467
+ img.format = 'JPG'
468
+ assert_equal('image/jpeg', img.mime_type)
469
+ assert_raise(NoMethodError) { img.mime_type = 'image/jpeg' }
470
+ end
471
+
472
+ def test_monitor
473
+ assert_raise(NoMethodError) { @img.monitor }
474
+ monitor = Proc.new { |name, q, s| puts name }
475
+ assert_nothing_raised { @img.monitor = monitor }
476
+ assert_nothing_raised { @img.monitor = nil }
477
+ end
478
+
479
+ def test_montage
480
+ assert_nothing_raised { @img.montage }
481
+ assert_nil(@img.montage)
482
+ end
483
+
484
+ def test_number_colors
485
+ assert_nothing_raised { @hat.number_colors }
486
+ assert_equal(27980, @hat.number_colors)
487
+ assert_raise(NoMethodError) { @hat.number_colors = 2 }
488
+ end
489
+
490
+ def test_offset
491
+ assert_nothing_raised { @img.offset }
492
+ assert_equal(0, @img.offset)
493
+ assert_nothing_raised { @img.offset = 10 }
494
+ assert_equal(10, @img.offset)
495
+ assert_raise(TypeError) { @img.offset = 'x' }
496
+ end
497
+
498
+ def test_opacity
499
+ assert_raise(NoMethodError) { @img.opacity }
500
+ assert_nothing_raised { @img.opacity = 50 }
501
+ assert_raise(TypeError) { @img.opacity = 'x' }
502
+ end
503
+
504
+ def test_orientation
505
+ assert_nothing_raised { @img.orientation }
506
+ assert_instance_of(Magick::OrientationType, @img.orientation)
507
+ assert_equal(Magick::UndefinedOrientation, @img.orientation)
508
+ assert_nothing_raised { @img.orientation = Magick::UndefinedOrientation }
509
+ assert_nothing_raised { @img.orientation = Magick::TopLeftOrientation }
510
+ assert_nothing_raised { @img.orientation = Magick::TopRightOrientation }
511
+ assert_nothing_raised { @img.orientation = Magick::BottomRightOrientation }
512
+ assert_nothing_raised { @img.orientation = Magick::LeftTopOrientation }
513
+ assert_nothing_raised { @img.orientation = Magick::RightTopOrientation }
514
+ assert_nothing_raised { @img.orientation = Magick::RightBottomOrientation }
515
+ assert_nothing_raised { @img.orientation = Magick::LeftBottomOrientation }
516
+ end
517
+
518
+ def test_page
519
+ assert_nothing_raised { @img.page }
520
+ page = @img.page
521
+ assert_equal(0, page.width)
522
+ assert_equal(0, page.height)
523
+ assert_equal(0, page.x)
524
+ assert_equal(0, page.y)
525
+ page = Magick::Rectangle.new(1,2,3,4)
526
+ assert_nothing_raised { @img.page = page }
527
+ assert_equal(1, page.width)
528
+ assert_equal(2, page.height)
529
+ assert_equal(3, page.x)
530
+ assert_equal(4, page.y)
531
+ assert_raise(TypeError) { @img.page = 2 }
532
+ end
533
+
534
+ def test_quality
535
+ assert_nothing_raised { @hat.quality }
536
+ assert_equal(75, @hat.quality)
537
+ assert_raise(NoMethodError) { @img.quality = 80 }
538
+ end
539
+
540
+ def test_quantum_depth
541
+ assert_nothing_raised { @img.quantum_depth }
542
+ assert_equal(Magick::QuantumDepth, @img.quantum_depth)
543
+ assert_raise(NoMethodError) { @img.quantum_depth = 8 }
544
+ end
545
+
546
+ def test_rendering_intent
547
+ assert_nothing_raised { @img.rendering_intent }
548
+ assert_instance_of(Magick::RenderingIntent, @img.rendering_intent)
549
+ assert_equal(Magick::UndefinedIntent, @img.rendering_intent)
550
+ assert_nothing_raised { @img.rendering_intent = Magick::SaturationIntent }
551
+ assert_nothing_raised { @img.rendering_intent = Magick::PerceptualIntent }
552
+ assert_nothing_raised { @img.rendering_intent = Magick::AbsoluteIntent }
553
+ assert_nothing_raised { @img.rendering_intent = Magick::RelativeIntent }
554
+ assert_raise(TypeError) { @img.rendering_intent = 2 }
555
+ end
556
+
557
+ def test_rows
558
+ assert_nothing_raised { @img.rows }
559
+ assert_equal(100, @img.rows)
560
+ assert_raise(NoMethodError) { @img.rows = 2 }
561
+ end
562
+
563
+ def test_scene
564
+ ilist = Magick::ImageList.new
565
+ ilist << @img
566
+ img = @img.copy
567
+ ilist << img
568
+ ilist.write('temp.gif')
569
+ FileUtils.rm('temp.gif')
570
+
571
+ assert_nothing_raised { img.scene }
572
+ assert_equal(0, @img.scene)
573
+ assert_equal(1, img.scene)
574
+ assert_raise(NoMethodError) { img.scene = 2 }
575
+ end
576
+
577
+ def test_start_loop
578
+ assert_nothing_raised { @img.start_loop }
579
+ assert(! @img.start_loop)
580
+ assert_nothing_raised { @img.start_loop = true }
581
+ assert(@img.start_loop)
582
+ end
583
+
584
+ def test_ticks_per_second
585
+ assert_nothing_raised { @img.ticks_per_second }
586
+ assert_equal(100, @img.ticks_per_second)
587
+ assert_nothing_raised { @img.ticks_per_second = 1000 }
588
+ assert_equal(1000, @img.ticks_per_second)
589
+ assert_raise(TypeError) { @img.ticks_per_second = 'x' }
590
+ end
591
+
592
+ def test_total_colors
593
+ assert_nothing_raised { @hat.total_colors }
594
+ assert_equal(27980, @hat.total_colors)
595
+ assert_raise(NoMethodError) { @img.total_colors = 2 }
596
+ end
597
+
598
+ def test_units
599
+ assert_nothing_raised { @img.units }
600
+ assert_instance_of(Magick::ResolutionType, @img.units)
601
+ assert_equal(Magick::UndefinedResolution, @img.units)
602
+ assert_nothing_raised { @img.units = Magick::PixelsPerInchResolution }
603
+ assert_equal(Magick::PixelsPerInchResolution, @img.units)
604
+ assert_nothing_raised { @img.units = Magick::PixelsPerCentimeterResolution }
605
+ assert_raise(TypeError) { @img.units = 2 }
606
+ end
607
+
608
+ def test_virtual_pixel_method
609
+ assert_nothing_raised { @img.virtual_pixel_method }
610
+ assert_equal(Magick::UndefinedVirtualPixelMethod, @img.virtual_pixel_method)
611
+ assert_nothing_raised { @img.virtual_pixel_method = Magick::EdgeVirtualPixelMethod }
612
+ assert_equal(Magick::EdgeVirtualPixelMethod, @img.virtual_pixel_method)
613
+ assert_nothing_raised { @img.virtual_pixel_method = Magick::MirrorVirtualPixelMethod }
614
+ assert_nothing_raised { @img.virtual_pixel_method = Magick::TileVirtualPixelMethod }
615
+ assert_nothing_raised { @img.virtual_pixel_method = Magick::TransparentVirtualPixelMethod }
616
+ assert_nothing_raised { @img.virtual_pixel_method = Magick::BackgroundVirtualPixelMethod }
617
+ assert_raise(TypeError) { @img.virtual_pixel_method = 2 }
618
+ end
619
+
620
+ def test_x_resolution
621
+ assert_nothing_raised { @img.x_resolution }
622
+ assert_equal(72.0, @img.x_resolution)
623
+ assert_nothing_raised { @img.x_resolution = 90 }
624
+ assert_equal(90.0, @img.x_resolution)
625
+ assert_raise(TypeError) { @img.x_resolution = 'x' }
626
+ end
627
+
628
+ def test_y_resolution
629
+ assert_nothing_raised { @img.y_resolution }
630
+ assert_equal(72.0, @img.y_resolution)
631
+ assert_nothing_raised { @img.y_resolution = 90 }
632
+ assert_equal(90.0, @img.y_resolution)
633
+ assert_raise(TypeError) { @img.y_resolution = 'x' }
634
+ end
635
+
636
+ def test_frozen
637
+ @img.freeze
638
+ assert_raise(FreezeError) { @img.background_color = 'xxx' }
639
+ assert_raise(FreezeError) { @img.blur = 50 }
640
+ assert_raise(FreezeError) { @img.border_color = 'xxx' }
641
+ rp = Magick::Point.new(1,1)
642
+ gp = Magick::Point.new(1,1)
643
+ bp = Magick::Point.new(1,1)
644
+ wp = Magick::Point.new(1,1)
645
+ assert_raise(FreezeError) { @img.chromaticity = Magick::Chromaticity.new(rp, gp, bp, wp) }
646
+ assert_raise(FreezeError) { @img.class_type = Magick::DirectClass }
647
+ assert_raise(FreezeError) { @img.color_profile = 'xxx' }
648
+ assert_raise(FreezeError) { @img.colorspace = Magick::RGBColorspace }
649
+ assert_raise(FreezeError) { @img.compose = Magick::OverCompositeOp }
650
+ assert_raise(FreezeError) { @img.compression = Magick::RLECompression }
651
+ assert_raise(FreezeError) { @img.delay = 2 }
652
+ assert_raise(FreezeError) { @img.density = '72.0x72.0' }
653
+ assert_raise(FreezeError) { @img.dispose = Magick::NoneDispose }
654
+ assert_raise(FreezeError) { @img.endian = Magick::MSBEndian }
655
+ assert_raise(FreezeError) { @img.extract_info = Magick::Rectangle.new(1,2,3,4) }
656
+ assert_raise(FreezeError) { @img.filter = Magick::PointFilter }
657
+ assert_raise(FreezeError) { @img.format = 'GIF' }
658
+ assert_raise(FreezeError) { @img.fuzz = 50.0 }
659
+ assert_raise(FreezeError) { @img.gamma = 2.0 }
660
+ assert_raise(FreezeError) { @img.geometry = '100x100' }
661
+ assert_raise(FreezeError) { @img.interlace = Magick::NoInterlace }
662
+ assert_raise(FreezeError) { @img.iptc_profile = 'xxx' }
663
+ assert_raise(FreezeError) { @img.mask = @img }
664
+ assert_raise(FreezeError) { @img.matte = true }
665
+ assert_raise(FreezeError) { @img.monitor = Proc.new { |name, q, s| puts name } }
666
+ assert_raise(FreezeError) { @img.offset = 100 }
667
+ assert_raise(FreezeError) { @img.opacity = 100 }
668
+ assert_raise(FreezeError) { @img.page = Magick::Rectangle.new(1,2,3,4) }
669
+ assert_raise(FreezeError) { @img.rendering_intent = Magick::SaturationIntent }
670
+ assert_raise(FreezeError) { @img.start_loop = true }
671
+ assert_raise(FreezeError) { @img.ticks_per_second = 1000 }
672
+ assert_raise(FreezeError) { @img.units = Magick::PixelsPerInchResolution }
673
+ assert_raise(FreezeError) { @img.x_resolution = 72.0 }
674
+ assert_raise(FreezeError) { @img.y_resolution = 72.0 }
675
+ end
676
+
677
+ end # class Image_Attributes_UT
678
+
679
+
680
+ if __FILE__ == $0
681
+ FLOWER_HAT = '../doc/ex/images/Flower_Hat.jpg'
682
+ Test::Unit::UI::Console::TestRunner.run(Image_Attributes_UT) if !RUBY_VERSION[/^1\.9|^2/]
683
+ end