rmagick-windows 2.16.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (393) hide show
  1. checksums.yaml +7 -0
  2. data/.editorconfig +14 -0
  3. data/.gitignore +23 -0
  4. data/.hound.yml +2 -0
  5. data/.rspec +1 -0
  6. data/.rubocop.yml +340 -0
  7. data/.simplecov +27 -0
  8. data/.travis.yml +60 -0
  9. data/CHANGELOG.md +915 -0
  10. data/CODE_OF_CONDUCT.md +13 -0
  11. data/CONTRIBUTING.md +50 -0
  12. data/Doxyfile +1514 -0
  13. data/Gemfile +10 -0
  14. data/LICENSE +20 -0
  15. data/README.textile +257 -0
  16. data/Rakefile +188 -0
  17. data/before_install_linux.sh +32 -0
  18. data/before_install_osx.sh +2 -0
  19. data/deprecated/RMagick.rb +6 -0
  20. data/doc/.cvsignore +1 -0
  21. data/doc/comtasks.html +287 -0
  22. data/doc/constants.html +1581 -0
  23. data/doc/css/doc.css +299 -0
  24. data/doc/css/popup.css +34 -0
  25. data/doc/css/ref.css +67 -0
  26. data/doc/draw.html +3272 -0
  27. data/doc/ex/InitialCoords.rb +22 -0
  28. data/doc/ex/NewCoordSys.rb +30 -0
  29. data/doc/ex/OrigCoordSys.rb +16 -0
  30. data/doc/ex/PreserveAspectRatio.rb +204 -0
  31. data/doc/ex/RotateScale.rb +36 -0
  32. data/doc/ex/Skew.rb +38 -0
  33. data/doc/ex/Use01.rb +15 -0
  34. data/doc/ex/Use02.rb +20 -0
  35. data/doc/ex/Use03.rb +16 -0
  36. data/doc/ex/ViewBox.rb +31 -0
  37. data/doc/ex/adaptive_threshold.rb +9 -0
  38. data/doc/ex/add_noise.rb +16 -0
  39. data/doc/ex/affine.rb +48 -0
  40. data/doc/ex/affine_transform.rb +20 -0
  41. data/doc/ex/arc.rb +49 -0
  42. data/doc/ex/arcpath.rb +32 -0
  43. data/doc/ex/arcs01.rb +28 -0
  44. data/doc/ex/arcs02.rb +59 -0
  45. data/doc/ex/average.rb +15 -0
  46. data/doc/ex/axes.rb +64 -0
  47. data/doc/ex/baseline_shift01.rb +17 -0
  48. data/doc/ex/bilevel_channel.rb +8 -0
  49. data/doc/ex/blur_image.rb +12 -0
  50. data/doc/ex/border.rb +10 -0
  51. data/doc/ex/bounding_box.rb +42 -0
  52. data/doc/ex/cbezier1.rb +41 -0
  53. data/doc/ex/cbezier2.rb +41 -0
  54. data/doc/ex/cbezier3.rb +41 -0
  55. data/doc/ex/cbezier4.rb +42 -0
  56. data/doc/ex/cbezier5.rb +42 -0
  57. data/doc/ex/cbezier6.rb +53 -0
  58. data/doc/ex/channel.rb +25 -0
  59. data/doc/ex/charcoal.rb +12 -0
  60. data/doc/ex/chop.rb +29 -0
  61. data/doc/ex/circle.rb +33 -0
  62. data/doc/ex/circle01.rb +16 -0
  63. data/doc/ex/clip_path.rb +60 -0
  64. data/doc/ex/coalesce.rb +57 -0
  65. data/doc/ex/color_fill_to_border.rb +29 -0
  66. data/doc/ex/color_floodfill.rb +28 -0
  67. data/doc/ex/color_histogram.rb +47 -0
  68. data/doc/ex/color_reset.rb +11 -0
  69. data/doc/ex/colorize.rb +16 -0
  70. data/doc/ex/colors.rb +64 -0
  71. data/doc/ex/compose_mask.rb +22 -0
  72. data/doc/ex/composite.rb +133 -0
  73. data/doc/ex/composite_layers.rb +53 -0
  74. data/doc/ex/composite_tiled.rb +21 -0
  75. data/doc/ex/contrast.rb +36 -0
  76. data/doc/ex/crop.rb +31 -0
  77. data/doc/ex/crop_with_gravity.rb +42 -0
  78. data/doc/ex/cubic01.rb +43 -0
  79. data/doc/ex/cubic02.rb +91 -0
  80. data/doc/ex/cycle_colormap.rb +21 -0
  81. data/doc/ex/dissolve.rb +12 -0
  82. data/doc/ex/drawcomp.rb +42 -0
  83. data/doc/ex/drop_shadow.rb +60 -0
  84. data/doc/ex/edge.rb +11 -0
  85. data/doc/ex/ellipse.rb +45 -0
  86. data/doc/ex/ellipse01.rb +21 -0
  87. data/doc/ex/emboss.rb +11 -0
  88. data/doc/ex/enhance.rb +28 -0
  89. data/doc/ex/equalize.rb +11 -0
  90. data/doc/ex/evenodd.rb +42 -0
  91. data/doc/ex/fill_pattern.rb +23 -0
  92. data/doc/ex/flatten_images.rb +36 -0
  93. data/doc/ex/flip.rb +11 -0
  94. data/doc/ex/flop.rb +11 -0
  95. data/doc/ex/font_styles.rb +32 -0
  96. data/doc/ex/fonts.rb +20 -0
  97. data/doc/ex/frame.rb +12 -0
  98. data/doc/ex/gaussian_blur.rb +11 -0
  99. data/doc/ex/get_multiline_type_metrics.rb +41 -0
  100. data/doc/ex/get_pixels.rb +47 -0
  101. data/doc/ex/get_type_metrics.rb +141 -0
  102. data/doc/ex/gradientfill.rb +27 -0
  103. data/doc/ex/grav.rb +45 -0
  104. data/doc/ex/gravity.rb +80 -0
  105. data/doc/ex/group.rb +26 -0
  106. data/doc/ex/hatchfill.rb +27 -0
  107. data/doc/ex/image.rb +44 -0
  108. data/doc/ex/images/Apple.miff +0 -0
  109. data/doc/ex/images/Ballerina.jpg +0 -0
  110. data/doc/ex/images/Ballerina3.jpg +0 -0
  111. data/doc/ex/images/Button_0.gif +0 -0
  112. data/doc/ex/images/Button_1.gif +0 -0
  113. data/doc/ex/images/Button_2.gif +0 -0
  114. data/doc/ex/images/Button_3.gif +0 -0
  115. data/doc/ex/images/Button_4.gif +0 -0
  116. data/doc/ex/images/Button_5.gif +0 -0
  117. data/doc/ex/images/Button_6.gif +0 -0
  118. data/doc/ex/images/Button_7.gif +0 -0
  119. data/doc/ex/images/Button_8.gif +0 -0
  120. data/doc/ex/images/Button_9.gif +0 -0
  121. data/doc/ex/images/Button_A.gif +0 -0
  122. data/doc/ex/images/Button_B.gif +0 -0
  123. data/doc/ex/images/Button_C.gif +0 -0
  124. data/doc/ex/images/Button_D.gif +0 -0
  125. data/doc/ex/images/Button_E.gif +0 -0
  126. data/doc/ex/images/Button_F.gif +0 -0
  127. data/doc/ex/images/Button_G.gif +0 -0
  128. data/doc/ex/images/Button_H.gif +0 -0
  129. data/doc/ex/images/Button_I.gif +0 -0
  130. data/doc/ex/images/Button_J.gif +0 -0
  131. data/doc/ex/images/Button_K.gif +0 -0
  132. data/doc/ex/images/Button_L.gif +0 -0
  133. data/doc/ex/images/Button_M.gif +0 -0
  134. data/doc/ex/images/Button_N.gif +0 -0
  135. data/doc/ex/images/Button_O.gif +0 -0
  136. data/doc/ex/images/Button_P.gif +0 -0
  137. data/doc/ex/images/Button_Q.gif +0 -0
  138. data/doc/ex/images/Button_R.gif +0 -0
  139. data/doc/ex/images/Button_S.gif +0 -0
  140. data/doc/ex/images/Button_T.gif +0 -0
  141. data/doc/ex/images/Button_U.gif +0 -0
  142. data/doc/ex/images/Button_V.gif +0 -0
  143. data/doc/ex/images/Button_W.gif +0 -0
  144. data/doc/ex/images/Button_X.gif +0 -0
  145. data/doc/ex/images/Button_Y.gif +0 -0
  146. data/doc/ex/images/Button_Z.gif +0 -0
  147. data/doc/ex/images/Cheetah.jpg +0 -0
  148. data/doc/ex/images/Coffee.wmf +0 -0
  149. data/doc/ex/images/Flower_Hat.jpg +0 -0
  150. data/doc/ex/images/Gold_Statue.jpg +0 -0
  151. data/doc/ex/images/Hot_Air_Balloons.jpg +0 -0
  152. data/doc/ex/images/Hot_Air_Balloons_H.jpg +0 -0
  153. data/doc/ex/images/Leaf.miff +0 -0
  154. data/doc/ex/images/No.wmf +0 -0
  155. data/doc/ex/images/Polynesia.jpg +0 -0
  156. data/doc/ex/images/Red_Rocks.jpg +0 -0
  157. data/doc/ex/images/Rocks_On_Beach.miff +0 -0
  158. data/doc/ex/images/Shorts.jpg +0 -0
  159. data/doc/ex/images/Snake.wmf +0 -0
  160. data/doc/ex/images/Violin.jpg +0 -0
  161. data/doc/ex/images/Yellow_Rose.miff +0 -0
  162. data/doc/ex/images/big-duck.gif +0 -0
  163. data/doc/ex/images/duck.gif +0 -0
  164. data/doc/ex/images/duck0.gif +0 -0
  165. data/doc/ex/images/duck1.gif +0 -0
  166. data/doc/ex/images/duck10.gif +0 -0
  167. data/doc/ex/images/duck11.gif +0 -0
  168. data/doc/ex/images/duck12.gif +0 -0
  169. data/doc/ex/images/duck13.gif +0 -0
  170. data/doc/ex/images/duck14.gif +0 -0
  171. data/doc/ex/images/duck15.gif +0 -0
  172. data/doc/ex/images/duck2.gif +0 -0
  173. data/doc/ex/images/duck3.gif +0 -0
  174. data/doc/ex/images/duck4.gif +0 -0
  175. data/doc/ex/images/duck5.gif +0 -0
  176. data/doc/ex/images/duck6.gif +0 -0
  177. data/doc/ex/images/duck7.gif +0 -0
  178. data/doc/ex/images/duck8.gif +0 -0
  179. data/doc/ex/images/duck9.gif +0 -0
  180. data/doc/ex/images/graydient230x6.gif +0 -0
  181. data/doc/ex/images/image_with_profile.jpg +0 -0
  182. data/doc/ex/images/logo400x83.gif +0 -0
  183. data/doc/ex/images/model.miff +0 -0
  184. data/doc/ex/images/notimplemented.gif +0 -0
  185. data/doc/ex/images/smile.miff +0 -0
  186. data/doc/ex/images/spin.gif +0 -0
  187. data/doc/ex/implode.rb +34 -0
  188. data/doc/ex/level.rb +11 -0
  189. data/doc/ex/level_colors.rb +11 -0
  190. data/doc/ex/line.rb +41 -0
  191. data/doc/ex/line01.rb +21 -0
  192. data/doc/ex/mask.rb +35 -0
  193. data/doc/ex/matte_fill_to_border.rb +39 -0
  194. data/doc/ex/matte_floodfill.rb +32 -0
  195. data/doc/ex/matte_replace.rb +39 -0
  196. data/doc/ex/median_filter.rb +28 -0
  197. data/doc/ex/modulate.rb +11 -0
  198. data/doc/ex/mono.rb +23 -0
  199. data/doc/ex/morph.rb +25 -0
  200. data/doc/ex/mosaic.rb +35 -0
  201. data/doc/ex/motion_blur.rb +11 -0
  202. data/doc/ex/negate.rb +11 -0
  203. data/doc/ex/negate_channel.rb +9 -0
  204. data/doc/ex/nested_rvg.rb +21 -0
  205. data/doc/ex/nonzero.rb +42 -0
  206. data/doc/ex/normalize.rb +11 -0
  207. data/doc/ex/oil_paint.rb +11 -0
  208. data/doc/ex/opacity.rb +37 -0
  209. data/doc/ex/ordered_dither.rb +11 -0
  210. data/doc/ex/path.rb +63 -0
  211. data/doc/ex/pattern1.rb +25 -0
  212. data/doc/ex/pattern2.rb +26 -0
  213. data/doc/ex/polaroid.rb +27 -0
  214. data/doc/ex/polygon.rb +23 -0
  215. data/doc/ex/polygon01.rb +21 -0
  216. data/doc/ex/polyline.rb +22 -0
  217. data/doc/ex/polyline01.rb +21 -0
  218. data/doc/ex/posterize.rb +8 -0
  219. data/doc/ex/preview.rb +8 -0
  220. data/doc/ex/qbezierpath.rb +52 -0
  221. data/doc/ex/quad01.rb +34 -0
  222. data/doc/ex/quantize-m.rb +25 -0
  223. data/doc/ex/radial_blur.rb +9 -0
  224. data/doc/ex/raise.rb +8 -0
  225. data/doc/ex/random_threshold_channel.rb +13 -0
  226. data/doc/ex/rect01.rb +14 -0
  227. data/doc/ex/rect02.rb +20 -0
  228. data/doc/ex/rectangle.rb +34 -0
  229. data/doc/ex/reduce_noise.rb +28 -0
  230. data/doc/ex/remap.rb +11 -0
  231. data/doc/ex/remap_images.rb +19 -0
  232. data/doc/ex/resize_to_fill.rb +8 -0
  233. data/doc/ex/resize_to_fit.rb +8 -0
  234. data/doc/ex/roll.rb +9 -0
  235. data/doc/ex/rotate.rb +44 -0
  236. data/doc/ex/rotate_f.rb +14 -0
  237. data/doc/ex/roundrect.rb +33 -0
  238. data/doc/ex/rubyname.rb +30 -0
  239. data/doc/ex/rvg_clippath.rb +12 -0
  240. data/doc/ex/rvg_linecap.rb +42 -0
  241. data/doc/ex/rvg_linejoin.rb +40 -0
  242. data/doc/ex/rvg_opacity.rb +18 -0
  243. data/doc/ex/rvg_pattern.rb +26 -0
  244. data/doc/ex/rvg_stroke_dasharray.rb +11 -0
  245. data/doc/ex/segment.rb +11 -0
  246. data/doc/ex/sepiatone.rb +7 -0
  247. data/doc/ex/shade.rb +11 -0
  248. data/doc/ex/shadow.rb +30 -0
  249. data/doc/ex/shave.rb +15 -0
  250. data/doc/ex/shear.rb +10 -0
  251. data/doc/ex/sketch.rb +17 -0
  252. data/doc/ex/skewx.rb +51 -0
  253. data/doc/ex/skewy.rb +47 -0
  254. data/doc/ex/smile.rb +125 -0
  255. data/doc/ex/solarize.rb +11 -0
  256. data/doc/ex/sparse_color.rb +54 -0
  257. data/doc/ex/splice.rb +8 -0
  258. data/doc/ex/spread.rb +11 -0
  259. data/doc/ex/stegano.rb +55 -0
  260. data/doc/ex/stroke_dasharray.rb +42 -0
  261. data/doc/ex/stroke_fill.rb +10 -0
  262. data/doc/ex/stroke_linecap.rb +44 -0
  263. data/doc/ex/stroke_linejoin.rb +48 -0
  264. data/doc/ex/stroke_width.rb +49 -0
  265. data/doc/ex/swirl.rb +17 -0
  266. data/doc/ex/text.rb +37 -0
  267. data/doc/ex/text01.rb +16 -0
  268. data/doc/ex/text_align.rb +36 -0
  269. data/doc/ex/text_antialias.rb +37 -0
  270. data/doc/ex/text_styles.rb +19 -0
  271. data/doc/ex/text_undercolor.rb +28 -0
  272. data/doc/ex/texture_fill_to_border.rb +34 -0
  273. data/doc/ex/texture_floodfill.rb +32 -0
  274. data/doc/ex/texturefill.rb +24 -0
  275. data/doc/ex/threshold.rb +13 -0
  276. data/doc/ex/to_blob.rb +13 -0
  277. data/doc/ex/translate.rb +39 -0
  278. data/doc/ex/transparent.rb +38 -0
  279. data/doc/ex/transpose.rb +9 -0
  280. data/doc/ex/transverse.rb +9 -0
  281. data/doc/ex/tref01.rb +24 -0
  282. data/doc/ex/triangle01.rb +15 -0
  283. data/doc/ex/trim.rb +23 -0
  284. data/doc/ex/tspan01.rb +17 -0
  285. data/doc/ex/tspan02.rb +17 -0
  286. data/doc/ex/tspan03.rb +19 -0
  287. data/doc/ex/unsharp_mask.rb +28 -0
  288. data/doc/ex/viewex.rb +33 -0
  289. data/doc/ex/vignette.rb +12 -0
  290. data/doc/ex/watermark.rb +27 -0
  291. data/doc/ex/wave.rb +9 -0
  292. data/doc/ex/wet_floor.rb +58 -0
  293. data/doc/ex/writing_mode01.rb +26 -0
  294. data/doc/ex/writing_mode02.rb +26 -0
  295. data/doc/ilist.html +2056 -0
  296. data/doc/image1.html +4680 -0
  297. data/doc/image2.html +3665 -0
  298. data/doc/image3.html +4522 -0
  299. data/doc/imageattrs.html +1638 -0
  300. data/doc/imusage.html +514 -0
  301. data/doc/index.html +416 -0
  302. data/doc/info.html +1499 -0
  303. data/doc/magick.html +565 -0
  304. data/doc/optequiv.html +2435 -0
  305. data/doc/rvg.html +975 -0
  306. data/doc/rvgclip.html +248 -0
  307. data/doc/rvggroup.html +305 -0
  308. data/doc/rvgimage.html +289 -0
  309. data/doc/rvgpattern.html +475 -0
  310. data/doc/rvgshape.html +406 -0
  311. data/doc/rvgstyle.html +270 -0
  312. data/doc/rvgtext.html +465 -0
  313. data/doc/rvgtspan.html +238 -0
  314. data/doc/rvgtut.html +530 -0
  315. data/doc/rvguse.html +145 -0
  316. data/doc/rvgxform.html +294 -0
  317. data/doc/scripts/doc.js +22 -0
  318. data/doc/scripts/stripeTables.js +23 -0
  319. data/doc/struct.html +1339 -0
  320. data/doc/usage.html +1621 -0
  321. data/examples/constitute.rb +7 -0
  322. data/examples/crop_with_gravity.rb +42 -0
  323. data/examples/demo.rb +324 -0
  324. data/examples/describe.rb +43 -0
  325. data/examples/find_similar_region.rb +34 -0
  326. data/examples/histogram.rb +321 -0
  327. data/examples/identify.rb +185 -0
  328. data/examples/image_opacity.rb +29 -0
  329. data/examples/import_export.rb +31 -0
  330. data/examples/pattern_fill.rb +38 -0
  331. data/examples/rotating_text.rb +44 -0
  332. data/examples/spinner.rb +49 -0
  333. data/examples/thumbnail.rb +64 -0
  334. data/examples/vignette.rb +78 -0
  335. data/ext/RMagick/extconf.rb +548 -0
  336. data/ext/RMagick/rmagick.c +401 -0
  337. data/ext/RMagick/rmagick.h +1287 -0
  338. data/ext/RMagick/rmdraw.c +2022 -0
  339. data/ext/RMagick/rmenum.c +1235 -0
  340. data/ext/RMagick/rmfill.c +720 -0
  341. data/ext/RMagick/rmilist.c +1270 -0
  342. data/ext/RMagick/rmimage.c +15427 -0
  343. data/ext/RMagick/rminfo.c +2590 -0
  344. data/ext/RMagick/rmmain.c +1741 -0
  345. data/ext/RMagick/rmmontage.c +519 -0
  346. data/ext/RMagick/rmpixel.c +1114 -0
  347. data/ext/RMagick/rmstruct.c +1124 -0
  348. data/ext/RMagick/rmutil.c +1754 -0
  349. data/lib/rmagick.rb +1 -0
  350. data/lib/rmagick/version.rb +6 -0
  351. data/lib/rmagick_internal.rb +1947 -0
  352. data/lib/rvg/clippath.rb +45 -0
  353. data/lib/rvg/container.rb +122 -0
  354. data/lib/rvg/deep_equal.rb +52 -0
  355. data/lib/rvg/describable.rb +47 -0
  356. data/lib/rvg/embellishable.rb +391 -0
  357. data/lib/rvg/misc.rb +723 -0
  358. data/lib/rvg/paint.rb +50 -0
  359. data/lib/rvg/pathdata.rb +126 -0
  360. data/lib/rvg/rvg.rb +283 -0
  361. data/lib/rvg/stretchable.rb +165 -0
  362. data/lib/rvg/stylable.rb +116 -0
  363. data/lib/rvg/text.rb +172 -0
  364. data/lib/rvg/transformable.rb +126 -0
  365. data/lib/rvg/units.rb +63 -0
  366. data/rmagick.gemspec +46 -0
  367. data/spec/rmagick/ImageList1_spec.rb +24 -0
  368. data/spec/rmagick/draw_spec.rb +156 -0
  369. data/spec/rmagick/image/blue_shift_spec.rb +16 -0
  370. data/spec/rmagick/image/composite_spec.rb +140 -0
  371. data/spec/rmagick/image/constitute_spec.rb +15 -0
  372. data/spec/rmagick/image/dispatch_spec.rb +18 -0
  373. data/spec/rmagick/image/from_blob_spec.rb +14 -0
  374. data/spec/rmagick/image/ping_spec.rb +14 -0
  375. data/spec/rmagick/image/properties_spec.rb +29 -0
  376. data/spec/spec_helper.rb +4 -0
  377. data/test/Image1.rb +565 -0
  378. data/test/Image2.rb +1304 -0
  379. data/test/Image3.rb +1030 -0
  380. data/test/ImageList1.rb +806 -0
  381. data/test/ImageList2.rb +385 -0
  382. data/test/Image_attributes.rb +697 -0
  383. data/test/Import_Export.rb +121 -0
  384. data/test/Info.rb +345 -0
  385. data/test/Magick.rb +321 -0
  386. data/test/Pixel.rb +116 -0
  387. data/test/Preview.rb +57 -0
  388. data/test/cmyk.icm +0 -0
  389. data/test/srgb.icm +0 -0
  390. data/test/test_all_basic.rb +38 -0
  391. data/test/tmpnam_test.rb +50 -0
  392. data/wercker.yml +10 -0
  393. metadata +509 -0
data/test/Image3.rb ADDED
@@ -0,0 +1,1030 @@
1
+ #!/usr/bin/env ruby -w
2
+
3
+ require 'rmagick'
4
+ require 'test/unit'
5
+ require 'test/unit/ui/console/testrunner' unless RUBY_VERSION[/^1\.9|^2/]
6
+ require 'fileutils'
7
+
8
+ ColorspaceTypes = [
9
+ Magick::RGBColorspace,
10
+ Magick::GRAYColorspace,
11
+ Magick::TransparentColorspace,
12
+ Magick::OHTAColorspace,
13
+ Magick::LabColorspace,
14
+ Magick::XYZColorspace,
15
+ Magick::YCbCrColorspace,
16
+ Magick::YCCColorspace,
17
+ Magick::YIQColorspace,
18
+ Magick::YPbPrColorspace,
19
+ Magick::YUVColorspace,
20
+ Magick::CMYKColorspace,
21
+ Magick::SRGBColorspace,
22
+ Magick::HSLColorspace,
23
+ Magick::HWBColorspace,
24
+ Magick::HSBColorspace,
25
+ Magick::Rec601LumaColorspace,
26
+ Magick::Rec601YCbCrColorspace,
27
+ Magick::Rec709LumaColorspace,
28
+ Magick::Rec709YCbCrColorspace,
29
+ Magick::LogColorspace
30
+ ]
31
+
32
+ Filters = [
33
+ Magick::PointFilter,
34
+ Magick::BoxFilter,
35
+ Magick::TriangleFilter,
36
+ Magick::HermiteFilter,
37
+ Magick::HanningFilter,
38
+ Magick::HammingFilter,
39
+ Magick::BlackmanFilter,
40
+ Magick::GaussianFilter,
41
+ Magick::QuadraticFilter,
42
+ Magick::CubicFilter,
43
+ Magick::CatromFilter,
44
+ Magick::MitchellFilter,
45
+ Magick::LanczosFilter,
46
+ Magick::BesselFilter,
47
+ Magick::SincFilter
48
+ ]
49
+
50
+ class Image3_UT < Test::Unit::TestCase
51
+ FreezeError = RUBY_VERSION[/^1\.9|^2/] ? RuntimeError : TypeError
52
+
53
+ def setup
54
+ @img = Magick::Image.new(20, 20)
55
+ @p = Magick::Image.read(IMAGE_WITH_PROFILE).first.color_profile
56
+ end
57
+
58
+ def test_profile!
59
+ assert_nothing_raised do
60
+ res = @img.profile!('*', nil)
61
+ assert_same(@img, res)
62
+ end
63
+ assert_nothing_raised { @img.profile!('icc', @p) }
64
+ assert_nothing_raised { @img.profile!('iptc', 'xxx') }
65
+ assert_nothing_raised { @img.profile!('icc', nil) }
66
+ assert_nothing_raised { @img.profile!('iptc', nil) }
67
+
68
+ @img.freeze
69
+ assert_raise(FreezeError) { @img.profile!('icc', 'xxx') }
70
+ assert_raise(FreezeError) { @img.profile!('*', nil) }
71
+ end
72
+
73
+ def test_quantize
74
+ assert_nothing_raised do
75
+ res = @img.quantize
76
+ assert_instance_of(Magick::Image, res)
77
+ end
78
+
79
+ ColorspaceTypes.each do |cs|
80
+ assert_nothing_raised { @img.quantize(256, cs) }
81
+ end
82
+ assert_nothing_raised { @img.quantize(256, Magick::RGBColorspace, false) }
83
+ assert_nothing_raised { @img.quantize(256, Magick::RGBColorspace, true) }
84
+ assert_nothing_raised { @img.quantize(256, Magick::RGBColorspace, Magick::NoDitherMethod) }
85
+ assert_nothing_raised { @img.quantize(256, Magick::RGBColorspace, Magick::RiemersmaDitherMethod) }
86
+ assert_nothing_raised { @img.quantize(256, Magick::RGBColorspace, Magick::FloydSteinbergDitherMethod) }
87
+ assert_nothing_raised { @img.quantize(256, Magick::RGBColorspace, true, 2) }
88
+ assert_nothing_raised { @img.quantize(256, Magick::RGBColorspace, true, 2, true) }
89
+ assert_raise(TypeError) { @img.quantize('x') }
90
+ assert_raise(TypeError) { @img.quantize(16, 2) }
91
+ assert_raise(TypeError) { @img.quantize(16, Magick::RGBColorspace, false, 'x') }
92
+ end
93
+
94
+ def test_quantum_operator
95
+ quantum_ops = [
96
+ Magick::AddQuantumOperator,
97
+ Magick::AndQuantumOperator,
98
+ Magick::DivideQuantumOperator,
99
+ Magick::LShiftQuantumOperator,
100
+ Magick::MultiplyQuantumOperator,
101
+ Magick::OrQuantumOperator,
102
+ Magick::RShiftQuantumOperator,
103
+ Magick::SubtractQuantumOperator,
104
+ Magick::XorQuantumOperator ]
105
+
106
+ assert_nothing_raised do
107
+ res = @img.quantum_operator(Magick::AddQuantumOperator, 2)
108
+ assert_instance_of(Magick::Image, res)
109
+ end
110
+ quantum_ops.each do |op|
111
+ assert_nothing_raised { @img.quantum_operator(op, 2) }
112
+ end
113
+ assert_nothing_raised { @img.quantum_operator(Magick::AddQuantumOperator, 2, Magick::RedChannel) }
114
+ assert_raise(TypeError) { @img.quantum_operator(2, 2) }
115
+ assert_raise(TypeError) { @img.quantum_operator(Magick::AddQuantumOperator, 'x') }
116
+ assert_raise(TypeError) { @img.quantum_operator(Magick::AddQuantumOperator, 2, 2) }
117
+ assert_raise(ArgumentError) { @img.quantum_operator(Magick::AddQuantumOperator, 2, Magick::RedChannel, 2) }
118
+ end
119
+
120
+ def test_radial_blur
121
+ assert_nothing_raised do
122
+ res = @img.radial_blur(30)
123
+ assert_instance_of(Magick::Image, res)
124
+ end
125
+ end
126
+
127
+ def test_radial_blur_channel
128
+ res = nil
129
+ assert_nothing_raised { res = @img.radial_blur_channel(30) }
130
+ assert_not_nil(res)
131
+ assert_instance_of(Magick::Image, res)
132
+ assert_nothing_raised { res = @img.radial_blur_channel(30, Magick::RedChannel) }
133
+ assert_nothing_raised { res = @img.radial_blur_channel(30, Magick::RedChannel, Magick::BlueChannel) }
134
+
135
+ assert_raise(ArgumentError) { @img.radial_blur_channel }
136
+ assert_raise(TypeError) { @img.radial_blur_channel(30, 2) }
137
+ end
138
+
139
+ def test_raise
140
+ assert_nothing_raised do
141
+ res = @img.raise
142
+ assert_instance_of(Magick::Image, res)
143
+ end
144
+ assert_nothing_raised { @img.raise(4) }
145
+ assert_nothing_raised { @img.raise(4,4) }
146
+ assert_nothing_raised { @img.raise(4,4, false) }
147
+ assert_raise(TypeError) { @img.raise('x') }
148
+ assert_raise(TypeError) { @img.raise(2, 'x') }
149
+ assert_raise(ArgumentError) { @img.raise(4, 4, false, 2) }
150
+ end
151
+
152
+ def test_random_threshold_channel
153
+ assert_nothing_raised do
154
+ res = @img.random_threshold_channel('20%')
155
+ assert_instance_of(Magick::Image, res)
156
+ end
157
+ threshold = Magick::Geometry.new(20)
158
+ assert_nothing_raised { @img.random_threshold_channel(threshold) }
159
+ assert_nothing_raised { @img.random_threshold_channel(threshold, Magick::RedChannel) }
160
+ assert_nothing_raised { @img.random_threshold_channel(threshold, Magick::RedChannel, Magick::BlueChannel) }
161
+ assert_raise(ArgumentError) { @img.random_threshold_channel }
162
+ assert_raise(TypeError) { @img.random_threshold_channel('20%', 2) }
163
+ end
164
+
165
+ def test_reduce_noise
166
+ assert_nothing_raised do
167
+ res = @img.reduce_noise(0)
168
+ assert_instance_of(Magick::Image, res)
169
+ end
170
+ assert_nothing_raised { @img.reduce_noise(4) }
171
+ end
172
+
173
+ def test_remap
174
+ remap_image = Magick::Image.new(20,20) {self.background_color = 'green'}
175
+ assert_nothing_raised { @img.remap(remap_image) }
176
+ assert_nothing_raised { @img.remap(remap_image, Magick::NoDitherMethod) }
177
+ assert_nothing_raised { @img.remap(remap_image, Magick::RiemersmaDitherMethod) }
178
+ assert_nothing_raised { @img.remap(remap_image, Magick::FloydSteinbergDitherMethod) }
179
+
180
+ assert_raise(ArgumentError) {@img.remap }
181
+ assert_raise(ArgumentError) {@img.remap(remap_image, Magick::NoDitherMethod, 1) }
182
+ assert_raise(TypeError) {@img.remap(remap_image, 1) }
183
+ end
184
+
185
+ def test_resample
186
+ @img.x_resolution = 72
187
+ @img.y_resolution = 72
188
+ assert_nothing_raised { @img.resample }
189
+ assert_nothing_raised { @img.resample(100) }
190
+ assert_nothing_raised { @img.resample(100, 100) }
191
+
192
+ @img.x_resolution = 0
193
+ @img.y_resolution = 0
194
+ assert_nothing_raised { @img.resample }
195
+ assert_nothing_raised { @img.resample(100) }
196
+ assert_nothing_raised { @img.resample(100, 100) }
197
+
198
+ girl = Magick::Image.read(IMAGES_DIR+'/Flower_Hat.jpg').first
199
+ assert_equal(240.0, girl.x_resolution)
200
+ assert_equal(240.0, girl.y_resolution)
201
+ res = girl.resample(120, 120)
202
+ assert_equal(100, res.columns)
203
+ assert_equal(125, res.rows)
204
+ assert_equal(120.0, res.x_resolution)
205
+ assert_equal(120.0, res.y_resolution)
206
+ assert_equal(200, girl.columns)
207
+ assert_equal(250, girl.rows)
208
+ assert_equal(240.0, girl.x_resolution)
209
+ assert_equal(240.0, girl.y_resolution)
210
+
211
+ Filters.each do |filter|
212
+ assert_nothing_raised { @img.resample(50, 50, filter) }
213
+ end
214
+ assert_nothing_raised { @img.resample(50, 50, Magick::PointFilter, 2.0) }
215
+
216
+ assert_raise(TypeError) { @img.resample('x') }
217
+ assert_raise(TypeError) { @img.resample(100, 'x') }
218
+ assert_raise(TypeError) { @img.resample(50, 50, 2) }
219
+ assert_raise(TypeError) { @img.resample(50, 50, Magick::CubicFilter, 'x') }
220
+ assert_raise(ArgumentError) { @img.resample(50, 50, Magick::SincFilter, 2.0, 'x') }
221
+ assert_raise(ArgumentError) { @img.resample(-100) }
222
+ assert_raise(ArgumentError) { @img.resample(100, -100) }
223
+ end
224
+
225
+ def test_resample!
226
+ assert_nothing_raised do
227
+ res = @img.resample!(50)
228
+ assert_same(@img, res)
229
+ end
230
+ @img.freeze
231
+ assert_raise(FreezeError) { @img.resample!(50) }
232
+ end
233
+
234
+ def test_resize
235
+ assert_nothing_raised do
236
+ res = @img.resize(2)
237
+ assert_instance_of(Magick::Image, res)
238
+ end
239
+ assert_nothing_raised { @img.resize(50,50) }
240
+
241
+ Filters.each do |filter|
242
+ assert_nothing_raised { @img.resize(50, 50, filter) }
243
+ end
244
+ assert_nothing_raised { @img.resize(50, 50, Magick::PointFilter, 2.0) }
245
+ assert_raise(TypeError) { @img.resize('x') }
246
+ assert_raise(TypeError) { @img.resize(50, 'x') }
247
+ assert_raise(TypeError) { @img.resize(50, 50, 2) }
248
+ assert_raise(TypeError) { @img.resize(50, 50, Magick::CubicFilter, 'x') }
249
+ assert_raise(ArgumentError) { @img.resize(50, 50, Magick::SincFilter, 2.0, 'x') }
250
+ assert_raise(ArgumentError) { @img.resize }
251
+ end
252
+
253
+ def test_resize!
254
+ assert_nothing_raised do
255
+ res = @img.resize!(2)
256
+ assert_same(@img, res)
257
+ end
258
+ @img.freeze
259
+ assert_raise(FreezeError) { @img.resize!(0.50) }
260
+ end
261
+
262
+ def test_resize_to_fill_0
263
+ changed = @img.resize_to_fill(@img.columns,@img.rows)
264
+ assert_equal(@img.columns, changed.columns)
265
+ assert_equal(@img.rows, changed.rows)
266
+ assert_not_same(changed, @img)
267
+ end
268
+
269
+ def test_resize_to_fill_1
270
+ @img = Magick::Image.new(200, 250)
271
+ @img.resize_to_fill!(100,100)
272
+ assert_equal(100, @img.columns)
273
+ assert_equal(100, @img.rows)
274
+ end
275
+
276
+ def test_resize_to_fill_2
277
+ @img = Magick::Image.new(200, 250)
278
+ changed = @img.resize_to_fill(300,100)
279
+ assert_equal(300, changed.columns)
280
+ assert_equal(100, changed.rows)
281
+ end
282
+
283
+ def test_resize_to_fill_3
284
+ @img = Magick::Image.new(200, 250)
285
+ changed = @img.resize_to_fill(100,300)
286
+ assert_equal(100, changed.columns)
287
+ assert_equal(300, changed.rows)
288
+ end
289
+
290
+ def test_resize_to_fill_4
291
+ @img = Magick::Image.new(200, 250)
292
+ changed = @img.resize_to_fill(300,350)
293
+ assert_equal(300, changed.columns)
294
+ assert_equal(350, changed.rows)
295
+ end
296
+
297
+ def test_resize_to_fill_5
298
+ changed = @img.resize_to_fill(20,400)
299
+ assert_equal(20, changed.columns)
300
+ assert_equal(400, changed.rows)
301
+ end
302
+
303
+ def test_resize_to_fill_6
304
+ changed = @img.resize_to_fill(3000,400)
305
+ assert_equal(3000, changed.columns)
306
+ assert_equal(400, changed.rows)
307
+ end
308
+
309
+ # Make sure the old name is still around
310
+ def test_resize_to_fill_7
311
+ assert_block {@img.respond_to? :crop_resized}
312
+ assert_block {@img.respond_to? :crop_resized!}
313
+ end
314
+
315
+ # 2nd argument defaults to the same value as the 1st argument
316
+ def test_resize_to_fill_8
317
+ changed = @img.resize_to_fill(100)
318
+ assert_equal(100, changed.columns)
319
+ assert_equal(100, changed.rows)
320
+ end
321
+
322
+ def test_resize_to_fit
323
+ img = Magick::Image.new(200, 250)
324
+ res = nil
325
+ assert_nothing_raised { res = img.resize_to_fit(50, 50) }
326
+ assert_not_nil(res)
327
+ assert_instance_of(Magick::Image, res)
328
+ assert_not_same(img, res)
329
+ assert_equal(40, res.columns)
330
+ assert_equal(50, res.rows)
331
+ end
332
+
333
+ def test_resize_to_fit2
334
+ img = Magick::Image.new(200, 300)
335
+ changed = img.resize_to_fit(100)
336
+ assert_instance_of(Magick::Image, changed)
337
+ assert_not_same(img, changed)
338
+ assert_equal(67, changed.columns)
339
+ assert_equal(100, changed.rows)
340
+ end
341
+
342
+ def test_resize_to_fit3
343
+ img = Magick::Image.new(200, 300)
344
+ keep = img
345
+ img.resize_to_fit!(100)
346
+ assert_instance_of(Magick::Image, img)
347
+ assert_same(img, keep)
348
+ assert_equal(67, img.columns)
349
+ assert_equal(100, img.rows)
350
+ end
351
+
352
+ def test_roll
353
+ assert_nothing_raised do
354
+ res = @img.roll(5, 5)
355
+ assert_instance_of(Magick::Image, res)
356
+ end
357
+ end
358
+
359
+ def test_rotate
360
+ assert_nothing_raised do
361
+ res = @img.rotate(45)
362
+ assert_instance_of(Magick::Image, res)
363
+ end
364
+ assert_nothing_raised { @img.rotate(-45) }
365
+
366
+ img = Magick::Image.new(100, 50)
367
+ assert_nothing_raised do
368
+ res = img.rotate(90, '>')
369
+ assert_instance_of(Magick::Image, res)
370
+ assert_equal(50, res.columns)
371
+ assert_equal(100, res.rows)
372
+ end
373
+ assert_nothing_raised do
374
+ res = img.rotate(90, '<')
375
+ assert_nil(res)
376
+ end
377
+ assert_raise(ArgumentError) { img.rotate(90, 't') }
378
+ assert_raise(TypeError) { img.rotate(90, []) }
379
+ end
380
+
381
+ def test_rotate!
382
+ assert_nothing_raised do
383
+ res = @img.rotate!(45)
384
+ assert_same(@img, res)
385
+ end
386
+ @img.freeze
387
+ assert_raise(FreezeError) { @img.rotate!(45) }
388
+ end
389
+
390
+ def test_sample
391
+ assert_nothing_raised do
392
+ res = @img.sample(10, 10)
393
+ assert_instance_of(Magick::Image, res)
394
+ end
395
+ assert_nothing_raised { @img.sample(2) }
396
+ assert_raise(ArgumentError) { @img.sample }
397
+ assert_raise(ArgumentError) { @img.sample(25, 25, 25) }
398
+ assert_raise(TypeError) { @img.sample('x') }
399
+ assert_raise(TypeError) { @img.sample(10, 'x') }
400
+ end
401
+
402
+ def test_sample!
403
+ assert_nothing_raised do
404
+ res = @img.sample!(2)
405
+ assert_same(@img, res)
406
+ end
407
+ @img.freeze
408
+ assert_raise(FreezeError) { @img.sample!(0.50) }
409
+ end
410
+
411
+ def test_scale
412
+ assert_nothing_raised do
413
+ res = @img.scale(10, 10)
414
+ assert_instance_of(Magick::Image, res)
415
+ end
416
+ assert_nothing_raised { @img.scale(2) }
417
+ assert_raise(ArgumentError) { @img.scale }
418
+ assert_raise(ArgumentError) { @img.scale(25, 25, 25) }
419
+ assert_raise(TypeError) { @img.scale('x') }
420
+ assert_raise(TypeError) { @img.scale(10, 'x') }
421
+ end
422
+
423
+ def test_scale!
424
+ assert_nothing_raised do
425
+ res = @img.scale!(2)
426
+ assert_same(@img, res)
427
+ end
428
+ @img.freeze
429
+ assert_raise(FreezeError) { @img.scale!(0.50) }
430
+ end
431
+
432
+ def test_segment
433
+ assert_nothing_raised do
434
+ res = @img.segment
435
+ assert_instance_of(Magick::Image, res)
436
+ end
437
+
438
+ # Don't test colorspaces that require PsuedoColor images
439
+ (ColorspaceTypes - [Magick::OHTAColorspace,
440
+ Magick::LabColorspace,
441
+ Magick::XYZColorspace,
442
+ Magick::YCbCrColorspace,
443
+ Magick::YCCColorspace,
444
+ Magick::YIQColorspace,
445
+ Magick::YPbPrColorspace,
446
+ Magick::YUVColorspace,
447
+ Magick::Rec601YCbCrColorspace,
448
+ Magick::Rec709YCbCrColorspace,
449
+ Magick::LogColorspace]).each do |cs|
450
+ assert_nothing_raised { @img.segment(cs) }
451
+ end
452
+
453
+ assert_nothing_raised { @img.segment(Magick::RGBColorspace, 2.0) }
454
+ assert_nothing_raised { @img.segment(Magick::RGBColorspace, 2.0, 2.0) }
455
+ assert_nothing_raised { @img.segment(Magick::RGBColorspace, 2.0, 2.0, false) }
456
+
457
+ assert_raise(ArgumentError) { @img.segment(Magick::RGBColorspace, 2.0, 2.0, false, 2) }
458
+ assert_raise(TypeError) { @img.segment(2) }
459
+ assert_raise(TypeError) { @img.segment(Magick::RGBColorspace, 'x') }
460
+ assert_raise(TypeError) { @img.segment(Magick::RGBColorspace, 2.0, 'x') }
461
+ end
462
+
463
+ def test_selective_blur_channel
464
+ res = nil
465
+ assert_nothing_raised { res = @img.selective_blur_channel(0, 1, '10%') }
466
+ assert_instance_of(Magick::Image, res)
467
+ assert_not_same(@img, res)
468
+ assert_equal([@img.columns, @img.rows], [res.columns, res.rows])
469
+
470
+ assert_nothing_raised { @img.selective_blur_channel(0, 1, 0.1) }
471
+ assert_nothing_raised { @img.selective_blur_channel(0, 1, '10%', Magick::RedChannel) }
472
+ assert_nothing_raised { @img.selective_blur_channel(0, 1, '10%', Magick::RedChannel, Magick::BlueChannel) }
473
+ assert_nothing_raised { @img.selective_blur_channel(0, 1, '10%', Magick::RedChannel, Magick::BlueChannel, Magick::GreenChannel) }
474
+ # not enough arguments
475
+ assert_raise(ArgumentError) { @img.selective_blur_channel(0, 1) }
476
+ end
477
+
478
+ def test_sepiatone
479
+ assert_nothing_raised do
480
+ res = @img.sepiatone
481
+ assert_instance_of(Magick::Image, res)
482
+ end
483
+ assert_nothing_raised { @img.sepiatone(Magick::QuantumRange*0.80) }
484
+ assert_raise(ArgumentError) { @img.sepiatone(Magick::QuantumRange, 2) }
485
+ assert_raise(TypeError) { @img.sepiatone('x') }
486
+ end
487
+
488
+ def test_set_channel_depth
489
+ channels = [
490
+ Magick::RedChannel,
491
+ Magick::GrayChannel,
492
+ Magick::CyanChannel,
493
+ Magick::GreenChannel,
494
+ Magick::MagentaChannel,
495
+ Magick::BlueChannel,
496
+ Magick::YellowChannel,
497
+ # Magick::AlphaChannel,
498
+ Magick::OpacityChannel,
499
+ Magick::MatteChannel,
500
+ Magick::BlackChannel,
501
+ Magick::IndexChannel,
502
+ Magick::AllChannels]
503
+
504
+ channels.each do |ch|
505
+ assert_nothing_raised {@img.set_channel_depth(ch, 8) }
506
+ end
507
+ end
508
+
509
+ def test_shade
510
+ assert_nothing_raised do
511
+ res = @img.shade
512
+ assert_instance_of(Magick::Image, res)
513
+ end
514
+ assert_nothing_raised { @img.shade(true) }
515
+ assert_nothing_raised { @img.shade(true, 30) }
516
+ assert_nothing_raised { @img.shade(true, 30, 30) }
517
+ assert_raise(ArgumentError) { @img.shade(true, 30, 30, 2) }
518
+ assert_raise(TypeError) { @img.shade(true, 'x') }
519
+ assert_raise(TypeError) { @img.shade(true, 30, 'x') }
520
+ end
521
+
522
+ def test_shadow
523
+ assert_nothing_raised do
524
+ res = @img.shadow
525
+ assert_instance_of(Magick::Image, res)
526
+ end
527
+ assert_nothing_raised { @img.shadow(5) }
528
+ assert_nothing_raised { @img.shadow(5, 5) }
529
+ assert_nothing_raised { @img.shadow(5, 5, 3.0) }
530
+ assert_nothing_raised { @img.shadow(5, 5, 3.0, 0.50) }
531
+ assert_nothing_raised { @img.shadow(5, 5, 3.0, '50%') }
532
+ assert_raise(ArgumentError) { @img.shadow(5, 5, 3.0, 0.50, 2) }
533
+ assert_raise(TypeError) { @img.shadow('x') }
534
+ assert_raise(TypeError) { @img.shadow(5, 'x') }
535
+ assert_raise(TypeError) { @img.shadow(5, 5, 'x') }
536
+ assert_raise(ArgumentError) { @img.shadow(5, 5, 3.0, 'x') }
537
+ end
538
+
539
+ def test_sharpen
540
+ assert_nothing_raised do
541
+ res = @img.sharpen
542
+ assert_instance_of(Magick::Image, res)
543
+ end
544
+ assert_nothing_raised { @img.sharpen(2.0) }
545
+ assert_nothing_raised { @img.sharpen(2.0, 1.0) }
546
+ assert_raise(ArgumentError) { @img.sharpen(2.0, 1.0, 2) }
547
+ assert_raise(TypeError) { @img.sharpen('x') }
548
+ assert_raise(TypeError) { @img.sharpen(2.0, 'x') }
549
+ end
550
+
551
+ def test_sharpen_channel
552
+ assert_nothing_raised do
553
+ res = @img.sharpen_channel
554
+ assert_instance_of(Magick::Image, res)
555
+ end
556
+ assert_nothing_raised { @img.sharpen_channel(2.0) }
557
+ assert_nothing_raised { @img.sharpen_channel(2.0, 1.0) }
558
+ assert_nothing_raised { @img.sharpen_channel(2.0, 1.0, Magick::RedChannel) }
559
+ assert_nothing_raised { @img.sharpen_channel(2.0, 1.0, Magick::RedChannel, Magick::BlueChannel) }
560
+ assert_raise(TypeError) { @img.sharpen_channel(2.0, 1.0, Magick::RedChannel, 2) }
561
+ assert_raise(TypeError) { @img.sharpen_channel('x') }
562
+ assert_raise(TypeError) { @img.sharpen_channel(2.0, 'x') }
563
+ end
564
+
565
+ def test_shave
566
+ assert_nothing_raised do
567
+ res = @img.shave(5,5)
568
+ assert_instance_of(Magick::Image, res)
569
+ end
570
+ assert_nothing_raised do
571
+ res = @img.shave!(5,5)
572
+ assert_same(@img, res)
573
+ end
574
+ @img.freeze
575
+ assert_raise(FreezeError) { @img.shave!(2,2) }
576
+ end
577
+
578
+ def test_shear
579
+ assert_nothing_raised do
580
+ res = @img.shear(30, 30)
581
+ assert_instance_of(Magick::Image, res)
582
+ end
583
+ end
584
+
585
+ def test_sigmoidal_contrast_channel
586
+ assert_nothing_raised do
587
+ res = @img.sigmoidal_contrast_channel
588
+ assert_instance_of(Magick::Image, res)
589
+ end
590
+ assert_nothing_raised { @img.sigmoidal_contrast_channel(3.0) }
591
+ assert_nothing_raised { @img.sigmoidal_contrast_channel(3.0, 50.0) }
592
+ assert_nothing_raised { @img.sigmoidal_contrast_channel(3.0, 50.0, true) }
593
+ assert_nothing_raised { @img.sigmoidal_contrast_channel(3.0, 50.0, true, Magick::RedChannel) }
594
+ assert_nothing_raised { @img.sigmoidal_contrast_channel(3.0, 50.0, true, Magick::RedChannel, Magick::BlueChannel) }
595
+ assert_raise(TypeError) { @img.sigmoidal_contrast_channel(3.0, 50.0, true, Magick::RedChannel, 2) }
596
+ assert_raise(TypeError) { @img.sigmoidal_contrast_channel('x') }
597
+ assert_raise(TypeError) { @img.sigmoidal_contrast_channel(3.0, 'x') }
598
+ end
599
+
600
+ def test_signature
601
+ assert_nothing_raised do
602
+ res = @img.signature
603
+ assert_instance_of(String, res)
604
+ end
605
+ end
606
+
607
+ def test_sketch
608
+ assert_nothing_raised { @img.sketch }
609
+ assert_nothing_raised { @img.sketch(0) }
610
+ assert_nothing_raised { @img.sketch(0, 1) }
611
+ assert_nothing_raised { @img.sketch(0, 1, 0) }
612
+ assert_raise(ArgumentError) { @img.sketch(0, 1, 0, 1) }
613
+ assert_raise(TypeError) { @img.sketch('x') }
614
+ assert_raise(TypeError) { @img.sketch(0, 'x') }
615
+ assert_raise(TypeError) { @img.sketch(0, 1, 'x') }
616
+ end
617
+
618
+ def test_solarize
619
+ assert_nothing_raised do
620
+ res = @img.solarize
621
+ assert_instance_of(Magick::Image, res)
622
+ end
623
+ assert_nothing_raised { @img.solarize(100) }
624
+ assert_raise(ArgumentError) { @img.solarize(100, 2) }
625
+ assert_raise(TypeError) { @img.solarize('x') }
626
+ end
627
+
628
+ def test_sparse_color
629
+ img = Magick::Image.new(100, 100)
630
+ args = [30, 10, 'red', 10, 80, 'blue', 70, 60, 'lime', 80, 20, 'yellow']
631
+ # assert good calls work
632
+ Magick::SparseColorMethod.values do |v|
633
+ next if v == Magick::UndefinedColorInterpolate
634
+ assert_nothing_raised { img.sparse_color(v, *args) }
635
+ end
636
+ args << Magick::RedChannel
637
+ assert_nothing_raised { img.sparse_color(Magick::VoronoiColorInterpolate, *args) }
638
+ args << Magick::GreenChannel
639
+ assert_nothing_raised { img.sparse_color(Magick::VoronoiColorInterpolate, *args) }
640
+ args << Magick::BlueChannel
641
+ assert_nothing_raised { img.sparse_color(Magick::VoronoiColorInterpolate, *args) }
642
+
643
+ # bad calls
644
+ args = [30, 10, 'red', 10, 80, 'blue', 70, 60, 'lime', 80, 20, 'yellow']
645
+ # invalid method
646
+ assert_raise(TypeError) { img.sparse_color(1, *args) }
647
+ # missing arguments
648
+ assert_raise(ArgumentError) { img.sparse_color(Magick::VoronoiColorInterpolate) }
649
+ args << 10 # too many arguments
650
+ assert_raise(ArgumentError) { img.sparse_color(Magick::VoronoiColorInterpolate, *args) }
651
+ args.shift
652
+ args.shift # too few
653
+ assert_raise(ArgumentError) { img.sparse_color(Magick::VoronoiColorInterpolate, *args) }
654
+ end
655
+
656
+ def test_splice
657
+ assert_nothing_raised do
658
+ res = @img.splice(0, 0, 2, 2)
659
+ assert_instance_of(Magick::Image, res)
660
+ end
661
+ assert_nothing_raised { @img.splice(0, 0, 2, 2, 'red') }
662
+ red = Magick::Pixel.new(Magick::QuantumRange)
663
+ assert_nothing_raised { @img.splice(0, 0, 2, 2, red) }
664
+ assert_raise(ArgumentError) { @img.splice(0,0, 2, 2, red, 'x') }
665
+ assert_raise(TypeError) { @img.splice([], 0, 2, 2, red) }
666
+ assert_raise(TypeError) { @img.splice(0, 'x', 2, 2, red) }
667
+ assert_raise(TypeError) { @img.splice(0, 0, 'x', 2, red) }
668
+ assert_raise(TypeError) { @img.splice(0, 0, 2, [], red) }
669
+ assert_raise(TypeError) { @img.splice(0, 0, 2, 2, /m/) }
670
+ end
671
+
672
+ def test_spread
673
+ assert_nothing_raised do
674
+ res = @img.spread
675
+ assert_instance_of(Magick::Image, res)
676
+ end
677
+ assert_nothing_raised { @img.spread(3.0) }
678
+ assert_raise(ArgumentError) { @img.spread(3.0, 2) }
679
+ assert_raise(TypeError) { @img.spread('x') }
680
+ end
681
+
682
+ def test_stegano
683
+ img = Magick::Image.new(100, 100) { self.background_color = 'black' }
684
+ watermark = Magick::Image.new(10, 10) { self.background_color = 'white' }
685
+ assert_nothing_raised do
686
+ res = @img.stegano(watermark, 0)
687
+ assert_instance_of(Magick::Image, res)
688
+ end
689
+
690
+ watermark.destroy!
691
+ assert_raise(Magick::DestroyedImageError) { @img.stegano(watermark, 0) }
692
+ end
693
+
694
+ def test_stereo
695
+ assert_nothing_raised do
696
+ res = @img.stereo(@img)
697
+ assert_instance_of(Magick::Image, res)
698
+ end
699
+
700
+ img = Magick::Image.new(20,20)
701
+ img.destroy!
702
+ assert_raise(Magick::DestroyedImageError) { @img.stereo(img) }
703
+ end
704
+
705
+ def test_store_pixels
706
+ pixels = @img.get_pixels(0, 0, @img.columns, 1)
707
+ assert_nothing_raised do
708
+ res = @img.store_pixels(0, 0, @img.columns, 1, pixels)
709
+ assert_same(@img, res)
710
+ end
711
+
712
+ pixels[0] = 'x'
713
+ assert_raise(TypeError) { @img.store_pixels(0, 0, @img.columns, 1, pixels) }
714
+ assert_raise(RangeError) { @img.store_pixels(-1, 0, @img.columns, 1, pixels) }
715
+ assert_raise(RangeError) { @img.store_pixels(0, -1, @img.columns, 1, pixels) }
716
+ assert_raise(RangeError) { @img.store_pixels(0, 0, 1+@img.columns, 1, pixels) }
717
+ assert_raise(RangeError) { @img.store_pixels(-1, 0, 1, 1+@img.rows, pixels) }
718
+ assert_raise(IndexError) { @img.store_pixels(0, 0, @img.columns, 1, ['x']) }
719
+ end
720
+
721
+ def test_strip!
722
+ assert_nothing_raised do
723
+ res = @img.strip!
724
+ assert_same(@img, res)
725
+ end
726
+ end
727
+
728
+ def test_swirl
729
+ assert_nothing_raised do
730
+ res = @img.swirl(30)
731
+ assert_instance_of(Magick::Image, res)
732
+ end
733
+ end
734
+
735
+ def test_sync_profiles
736
+ assert_nothing_raised { assert(@img.sync_profiles) }
737
+ end
738
+
739
+ def test_texture_fill_to_border
740
+ texture = Magick::Image.read('granite:').first
741
+ assert_nothing_raised do
742
+ res = @img.texture_fill_to_border(@img.columns/2, @img.rows/2, texture)
743
+ assert_instance_of(Magick::Image, res)
744
+ end
745
+ assert_raise(NoMethodError) { @img.texture_fill_to_border(@img.columns/2, @img.rows/2, 'x') }
746
+ end
747
+
748
+ def test_texture_floodfill
749
+ texture = Magick::Image.read('granite:').first
750
+ assert_nothing_raised do
751
+ res = @img.texture_floodfill(@img.columns/2, @img.rows/2, texture)
752
+ assert_instance_of(Magick::Image, res)
753
+ end
754
+ assert_raise(NoMethodError) { @img.texture_floodfill(@img.columns/2, @img.rows/2, 'x') }
755
+ texture.destroy!
756
+ assert_raise(Magick::DestroyedImageError) { @img.texture_floodfill(@img.columns/2, @img.rows/2, texture) }
757
+ end
758
+
759
+ def test_threshold
760
+ assert_nothing_raised do
761
+ res = @img.threshold(100)
762
+ assert_instance_of(Magick::Image, res)
763
+ end
764
+ end
765
+
766
+ def test_thumbnail
767
+ assert_nothing_raised do
768
+ res = @img.thumbnail(10, 10)
769
+ assert_instance_of(Magick::Image, res)
770
+ end
771
+ assert_nothing_raised { @img.thumbnail(2) }
772
+ assert_raise(ArgumentError) { @img.thumbnail }
773
+ assert_raise(ArgumentError) { @img.thumbnail(25, 25, 25) }
774
+ assert_raise(TypeError) { @img.thumbnail('x') }
775
+ assert_raise(TypeError) { @img.thumbnail(10, 'x') }
776
+ end
777
+
778
+ def test_thumbnail!
779
+ assert_nothing_raised do
780
+ res = @img.thumbnail!(2)
781
+ assert_same(@img, res)
782
+ end
783
+ @img.freeze
784
+ assert_raise(FreezeError) { @img.thumbnail!(0.50) }
785
+ end
786
+
787
+ def test_to_blob
788
+ res = nil
789
+ assert_nothing_raised { res = @img.to_blob { self.format = 'miff' } }
790
+ assert_instance_of(String, res)
791
+ restored = Magick::Image.from_blob(res)
792
+ assert_equal(@img, restored[0])
793
+ end
794
+
795
+ def test_to_color
796
+ red = Magick::Pixel.new(Magick::QuantumRange)
797
+ assert_nothing_raised do
798
+ res = @img.to_color(red)
799
+ assert_equal('red', res)
800
+ end
801
+ end
802
+
803
+ def test_transparent
804
+ assert_nothing_raised do
805
+ res = @img.transparent('white')
806
+ assert_instance_of(Magick::Image, res)
807
+ end
808
+ pixel = Magick::Pixel.new
809
+ assert_nothing_raised { @img.transparent(pixel) }
810
+ assert_nothing_raised { @img.transparent('white', Magick::TransparentOpacity) }
811
+ assert_raise(ArgumentError) { @img.transparent('white', Magick::TransparentOpacity, 2) }
812
+ assert_nothing_raised { @img.transparent('white', Magick::QuantumRange/2) }
813
+ assert_raise(TypeError) { @img.transparent(2) }
814
+ end
815
+
816
+ def test_transpose
817
+ assert_nothing_raised do
818
+ res = @img.transpose
819
+ assert_instance_of(Magick::Image, res)
820
+ assert_not_same(@img, res)
821
+ end
822
+ assert_nothing_raised do
823
+ res = @img.transpose!
824
+ assert_instance_of(Magick::Image, res)
825
+ assert_same(@img, res)
826
+ end
827
+ end
828
+
829
+ def test_transverse
830
+ assert_nothing_raised do
831
+ res = @img.transverse
832
+ assert_instance_of(Magick::Image, res)
833
+ assert_not_same(@img, res)
834
+ end
835
+ assert_nothing_raised do
836
+ res = @img.transverse!
837
+ assert_instance_of(Magick::Image, res)
838
+ assert_same(@img, res)
839
+ end
840
+ end
841
+
842
+ def test_trim
843
+ # Can't use the default image because it's a solid color
844
+ hat = Magick::Image.read(IMAGES_DIR+'/Flower_Hat.jpg').first
845
+ assert_nothing_raised do
846
+ res = hat.trim
847
+ assert_instance_of(Magick::Image, res)
848
+ end
849
+ assert_nothing_raised do
850
+ res = hat.trim!
851
+ assert_same(hat, res)
852
+ end
853
+ end
854
+
855
+ def test_unique_colors
856
+ assert_nothing_raised do
857
+ res = @img.unique_colors
858
+ assert_instance_of(Magick::Image, res)
859
+ assert_equal(1, res.columns)
860
+ assert_equal(1, res.rows)
861
+ end
862
+ end
863
+
864
+ def test_unsharp_mask
865
+ assert_nothing_raised do
866
+ res = @img.unsharp_mask
867
+ assert_instance_of(Magick::Image, res)
868
+ end
869
+
870
+ assert_nothing_raised { @img.unsharp_mask(2.0) }
871
+ assert_nothing_raised { @img.unsharp_mask(2.0, 1.0) }
872
+ assert_nothing_raised { @img.unsharp_mask(2.0, 1.0, 0.50) }
873
+ assert_nothing_raised { @img.unsharp_mask(2.0, 1.0, 0.50, 0.10) }
874
+ assert_raise(ArgumentError) { @img.unsharp_mask(2.0, 1.0, 0.50, 0.10, 2) }
875
+ assert_raise(TypeError) { @img.unsharp_mask('x') }
876
+ assert_raise(TypeError) { @img.unsharp_mask(2.0, 'x') }
877
+ assert_raise(TypeError) { @img.unsharp_mask(2.0, 1.0, 'x') }
878
+ assert_raise(TypeError) { @img.unsharp_mask(2.0, 1.0, 0.50, 'x') }
879
+ end
880
+
881
+ def test_unsharp_mask_channel
882
+ assert_nothing_raised do
883
+ res = @img.unsharp_mask_channel
884
+ assert_instance_of(Magick::Image, res)
885
+ end
886
+
887
+ assert_nothing_raised { @img.unsharp_mask_channel(2.0) }
888
+ assert_nothing_raised { @img.unsharp_mask_channel(2.0, 1.0) }
889
+ assert_nothing_raised { @img.unsharp_mask_channel(2.0, 1.0, 0.50) }
890
+ assert_nothing_raised { @img.unsharp_mask_channel(2.0, 1.0, 0.50, 0.10) }
891
+ assert_nothing_raised { @img.unsharp_mask_channel(2.0, 1.0, 0.50, 0.10, Magick::RedChannel) }
892
+ assert_nothing_raised { @img.unsharp_mask_channel(2.0, 1.0, 0.50, 0.10, Magick::RedChannel, Magick::BlueChannel) }
893
+ assert_raise(TypeError) { @img.unsharp_mask_channel(2.0, 1.0, 0.50, 0.10, Magick::RedChannel, 2) }
894
+ assert_raise(TypeError) { @img.unsharp_mask_channel(2.0, 1.0, 0.50, 0.10, 2) }
895
+ assert_raise(TypeError) { @img.unsharp_mask_channel('x') }
896
+ assert_raise(TypeError) { @img.unsharp_mask_channel(2.0, 'x') }
897
+ assert_raise(TypeError) { @img.unsharp_mask_channel(2.0, 1.0, 'x') }
898
+ assert_raise(TypeError) { @img.unsharp_mask_channel(2.0, 1.0, 0.50, 'x') }
899
+ end
900
+
901
+ def test_view
902
+ assert_nothing_raised do
903
+ res = @img.view(0, 0, 5, 5)
904
+ assert_instance_of(Magick::Image::View, res)
905
+ end
906
+ assert_nothing_raised do
907
+ @img.view(0, 0, 5, 5) { |v| assert_instance_of(Magick::Image::View, v) }
908
+ end
909
+ assert_raise(RangeError) { @img.view(-1, 0, 5, 5) }
910
+ assert_raise(RangeError) { @img.view(0, -1, 5, 5) }
911
+ assert_raise(RangeError) { @img.view(1, 0, @img.columns, 5) }
912
+ assert_raise(RangeError) { @img.view(0, 1, 5, @img.rows) }
913
+ assert_raise(ArgumentError) { @img.view(0, 0, 0, 1) }
914
+ assert_raise(ArgumentError) { @img.view(0, 0, 1, 0) }
915
+ end
916
+
917
+ def test_vignette
918
+ assert_nothing_raised do
919
+ res = @img.vignette
920
+ assert_instance_of(Magick::Image, res)
921
+ assert_not_same(res, @img)
922
+ end
923
+ assert_nothing_raised { @img.vignette(0) }
924
+ assert_nothing_raised { @img.vignette(0, 0) }
925
+ assert_nothing_raised { @img.vignette(0, 0, 0) }
926
+ assert_nothing_raised { @img.vignette(0, 0, 0, 1) }
927
+ # too many arguments
928
+ assert_raise(ArgumentError) { @img.vignette(0, 0, 0, 1, 1) }
929
+ end
930
+
931
+ def test_watermark
932
+ mark = Magick::Image.new(5,5)
933
+ mark_list = Magick::ImageList.new
934
+ mark_list << mark.copy
935
+ assert_nothing_raised { @img.watermark(mark) }
936
+ assert_nothing_raised { @img.watermark(mark_list) }
937
+ assert_nothing_raised { @img.watermark(mark, 0.50) }
938
+ assert_nothing_raised { @img.watermark(mark, '50%') }
939
+ assert_nothing_raised { @img.watermark(mark, 0.50, 0.50) }
940
+ assert_nothing_raised { @img.watermark(mark, 0.50, '50%') }
941
+ assert_nothing_raised { @img.watermark(mark, 0.50, 0.50, 10) }
942
+ assert_nothing_raised { @img.watermark(mark, 0.50, 0.50, 10, 10) }
943
+ assert_nothing_raised { @img.watermark(mark, 0.50, 0.50, Magick::NorthEastGravity) }
944
+ assert_nothing_raised { @img.watermark(mark, 0.50, 0.50, Magick::NorthEastGravity, 10) }
945
+ assert_nothing_raised { @img.watermark(mark, 0.50, 0.50, Magick::NorthEastGravity, 10, 10) }
946
+
947
+ assert_raise(ArgumentError) { @img.watermark(mark, 'x') }
948
+ assert_raise(ArgumentError) { @img.watermark(mark, 0.50, 'x') }
949
+ assert_raise(TypeError) { @img.watermark(mark, 0.50, 0.50, 'x') }
950
+ assert_raise(TypeError) { @img.watermark(mark, 0.50, 0.50, Magick::NorthEastGravity, 'x') }
951
+ assert_raise(TypeError) { @img.watermark(mark, 0.50, 0.50, Magick::NorthEastGravity, 10, 'x') }
952
+
953
+ mark.destroy!
954
+ assert_raise(Magick::DestroyedImageError) { @img.watermark(mark) }
955
+ end
956
+
957
+ def test_wave
958
+ assert_nothing_raised do
959
+ res = @img.wave
960
+ assert_instance_of(Magick::Image, res)
961
+ end
962
+ assert_nothing_raised { @img.wave(25) }
963
+ assert_nothing_raised { @img.wave(25, 200) }
964
+ assert_raise(ArgumentError) { @img.wave(25, 200, 2) }
965
+ assert_raise(TypeError) { @img.wave('x') }
966
+ assert_raise(TypeError) { @img.wave(25, 'x') }
967
+ end
968
+
969
+ def test_white_threshold
970
+ assert_raise(ArgumentError) { @img.white_threshold }
971
+ assert_nothing_raised { @img.white_threshold(50) }
972
+ assert_nothing_raised { @img.white_threshold(50, 50) }
973
+ assert_nothing_raised { @img.white_threshold(50, 50, 50) }
974
+ assert_nothing_raised { @img.white_threshold(50, 50, 50, 50) }
975
+ assert_raise(ArgumentError) { @img.white_threshold(50, 50, 50, 50, 50) }
976
+ res = @img.white_threshold(50)
977
+ assert_instance_of(Magick::Image, res)
978
+ end
979
+
980
+ # test write with #format= attribute
981
+ def test_write
982
+ @img.write('temp.gif')
983
+ img = Magick::Image.read('temp.gif')
984
+ assert_equal('GIF', img.first.format)
985
+ FileUtils.rm('temp.gif')
986
+
987
+ @img.write('jpg:temp.foo')
988
+ img = Magick::Image.read('temp.foo')
989
+ assert_equal('JPEG', img.first.format)
990
+ FileUtils.rm('temp.foo')
991
+
992
+ @img.write('temp.0') { self.format = 'JPEG' }
993
+ img = Magick::Image.read('temp.0')
994
+ assert_equal('JPEG', img.first.format)
995
+
996
+ # JPEG has two names.
997
+ @img.write('jpeg:temp.0') { self.format = 'JPEG' }
998
+ img = Magick::Image.read('temp.0')
999
+ assert_equal('JPEG', img.first.format)
1000
+
1001
+ @img.write('jpg:temp.0') { self.format = 'JPG' }
1002
+ img = Magick::Image.read('temp.0')
1003
+ assert_equal('JPEG', img.first.format)
1004
+
1005
+ @img.write('jpg:temp.0') { self.format = 'JPEG' }
1006
+ img = Magick::Image.read('temp.0')
1007
+ assert_equal('JPEG', img.first.format)
1008
+
1009
+ @img.write('jpeg:temp.0') { self.format = 'JPG' }
1010
+ img = Magick::Image.read('temp.0')
1011
+ assert_equal('JPEG', img.first.format)
1012
+
1013
+ assert_raise(RuntimeError) do
1014
+ @img.write('gif:temp.0') { self.format = 'JPEG' }
1015
+ end
1016
+
1017
+ f = File.new('test.0', 'w')
1018
+ @img.write(f) { self.format = 'JPEG' }
1019
+ f.close
1020
+ img = Magick::Image.read('test.0')
1021
+ assert_equal('JPEG', img.first.format)
1022
+ FileUtils.rm('test.0')
1023
+ end
1024
+ end
1025
+
1026
+ if __FILE__ == $PROGRAM_NAME
1027
+ IMAGES_DIR = '../doc/ex/images'
1028
+ FILES = Dir[IMAGES_DIR+'/Button_*.gif']
1029
+ Test::Unit::UI::Console::TestRunner.run(Image3_UT) unless RUBY_VERSION[/^1\.9|^2/]
1030
+ end