rmagick 2.16.0 → 5.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (404) hide show
  1. checksums.yaml +5 -5
  2. data/.devcontainer/Dockerfile +14 -0
  3. data/.devcontainer/ImageMagick6/devcontainer.json +11 -0
  4. data/.devcontainer/devcontainer.json +11 -0
  5. data/.devcontainer/setup-repo.sh +10 -0
  6. data/.devcontainer/setup-user.sh +45 -0
  7. data/.editorconfig +3 -0
  8. data/.github/ISSUE_TEMPLATE.md +17 -0
  9. data/.github/workflows/ci.yml +138 -0
  10. data/.gitignore +7 -1
  11. data/.rspec +1 -0
  12. data/.rubocop.yml +37 -340
  13. data/.rubocop_todo.yml +448 -0
  14. data/.yardopts +5 -0
  15. data/CHANGELOG.md +455 -0
  16. data/CODE_OF_CONDUCT.md +122 -7
  17. data/CONTRIBUTING.md +37 -6
  18. data/Gemfile +0 -6
  19. data/README.md +316 -0
  20. data/Rakefile +74 -100
  21. data/before_install_linux.sh +65 -28
  22. data/before_install_osx.sh +58 -2
  23. data/ext/RMagick/extconf.rb +287 -393
  24. data/ext/RMagick/rmagick.c +106 -111
  25. data/ext/RMagick/rmagick.h +235 -331
  26. data/ext/RMagick/rmagick_gvl.h +224 -0
  27. data/ext/RMagick/rmdraw.c +516 -843
  28. data/ext/RMagick/rmenum.c +316 -755
  29. data/ext/RMagick/rmfill.c +281 -191
  30. data/ext/RMagick/rmilist.c +451 -456
  31. data/ext/RMagick/rmimage.c +6250 -5290
  32. data/ext/RMagick/rminfo.c +721 -894
  33. data/ext/RMagick/rmkinfo.c +228 -0
  34. data/ext/RMagick/rmmain.c +735 -521
  35. data/ext/RMagick/rmmontage.c +127 -172
  36. data/ext/RMagick/rmpixel.c +638 -431
  37. data/ext/RMagick/rmstruct.c +102 -282
  38. data/ext/RMagick/rmutil.c +450 -363
  39. data/lib/rmagick/version.rb +5 -4
  40. data/lib/rmagick.rb +2 -0
  41. data/lib/rmagick_internal.rb +349 -413
  42. data/lib/rvg/clippath.rb +3 -4
  43. data/lib/rvg/container.rb +30 -22
  44. data/lib/rvg/deep_equal.rb +11 -11
  45. data/lib/rvg/describable.rb +2 -2
  46. data/lib/rvg/embellishable.rb +63 -68
  47. data/lib/rvg/misc.rb +136 -139
  48. data/lib/rvg/paint.rb +2 -1
  49. data/lib/rvg/pathdata.rb +7 -8
  50. data/lib/rvg/rvg.rb +47 -46
  51. data/lib/rvg/stretchable.rb +22 -28
  52. data/lib/rvg/stylable.rb +12 -10
  53. data/lib/rvg/text.rb +169 -165
  54. data/lib/rvg/transformable.rb +17 -16
  55. data/lib/rvg/units.rb +5 -5
  56. data/rmagick.gemspec +16 -39
  57. metadata +114 -392
  58. data/.hound.yml +0 -2
  59. data/.simplecov +0 -27
  60. data/.travis.yml +0 -74
  61. data/Doxyfile +0 -1514
  62. data/README.textile +0 -251
  63. data/deprecated/RMagick.rb +0 -6
  64. data/doc/.cvsignore +0 -1
  65. data/doc/comtasks.html +0 -287
  66. data/doc/constants.html +0 -1581
  67. data/doc/css/doc.css +0 -299
  68. data/doc/css/popup.css +0 -34
  69. data/doc/css/ref.css +0 -67
  70. data/doc/draw.html +0 -3272
  71. data/doc/ex/InitialCoords.rb +0 -22
  72. data/doc/ex/NewCoordSys.rb +0 -30
  73. data/doc/ex/OrigCoordSys.rb +0 -16
  74. data/doc/ex/PreserveAspectRatio.rb +0 -204
  75. data/doc/ex/RotateScale.rb +0 -36
  76. data/doc/ex/Skew.rb +0 -38
  77. data/doc/ex/Use01.rb +0 -15
  78. data/doc/ex/Use02.rb +0 -20
  79. data/doc/ex/Use03.rb +0 -16
  80. data/doc/ex/ViewBox.rb +0 -31
  81. data/doc/ex/adaptive_threshold.rb +0 -9
  82. data/doc/ex/add_noise.rb +0 -16
  83. data/doc/ex/affine.rb +0 -48
  84. data/doc/ex/affine_transform.rb +0 -20
  85. data/doc/ex/arc.rb +0 -49
  86. data/doc/ex/arcpath.rb +0 -32
  87. data/doc/ex/arcs01.rb +0 -28
  88. data/doc/ex/arcs02.rb +0 -59
  89. data/doc/ex/average.rb +0 -15
  90. data/doc/ex/axes.rb +0 -64
  91. data/doc/ex/baseline_shift01.rb +0 -17
  92. data/doc/ex/bilevel_channel.rb +0 -8
  93. data/doc/ex/blur_image.rb +0 -12
  94. data/doc/ex/border.rb +0 -10
  95. data/doc/ex/bounding_box.rb +0 -42
  96. data/doc/ex/cbezier1.rb +0 -41
  97. data/doc/ex/cbezier2.rb +0 -41
  98. data/doc/ex/cbezier3.rb +0 -41
  99. data/doc/ex/cbezier4.rb +0 -42
  100. data/doc/ex/cbezier5.rb +0 -42
  101. data/doc/ex/cbezier6.rb +0 -53
  102. data/doc/ex/channel.rb +0 -25
  103. data/doc/ex/charcoal.rb +0 -12
  104. data/doc/ex/chop.rb +0 -29
  105. data/doc/ex/circle.rb +0 -33
  106. data/doc/ex/circle01.rb +0 -16
  107. data/doc/ex/clip_path.rb +0 -60
  108. data/doc/ex/coalesce.rb +0 -57
  109. data/doc/ex/color_fill_to_border.rb +0 -29
  110. data/doc/ex/color_floodfill.rb +0 -28
  111. data/doc/ex/color_histogram.rb +0 -47
  112. data/doc/ex/color_reset.rb +0 -11
  113. data/doc/ex/colorize.rb +0 -16
  114. data/doc/ex/colors.rb +0 -64
  115. data/doc/ex/compose_mask.rb +0 -22
  116. data/doc/ex/composite.rb +0 -133
  117. data/doc/ex/composite_layers.rb +0 -53
  118. data/doc/ex/composite_tiled.rb +0 -21
  119. data/doc/ex/contrast.rb +0 -36
  120. data/doc/ex/crop.rb +0 -31
  121. data/doc/ex/crop_with_gravity.rb +0 -42
  122. data/doc/ex/cubic01.rb +0 -43
  123. data/doc/ex/cubic02.rb +0 -91
  124. data/doc/ex/cycle_colormap.rb +0 -21
  125. data/doc/ex/dissolve.rb +0 -12
  126. data/doc/ex/drawcomp.rb +0 -42
  127. data/doc/ex/drop_shadow.rb +0 -60
  128. data/doc/ex/edge.rb +0 -11
  129. data/doc/ex/ellipse.rb +0 -45
  130. data/doc/ex/ellipse01.rb +0 -21
  131. data/doc/ex/emboss.rb +0 -11
  132. data/doc/ex/enhance.rb +0 -28
  133. data/doc/ex/equalize.rb +0 -11
  134. data/doc/ex/evenodd.rb +0 -42
  135. data/doc/ex/fill_pattern.rb +0 -23
  136. data/doc/ex/flatten_images.rb +0 -36
  137. data/doc/ex/flip.rb +0 -11
  138. data/doc/ex/flop.rb +0 -11
  139. data/doc/ex/font_styles.rb +0 -32
  140. data/doc/ex/fonts.rb +0 -20
  141. data/doc/ex/frame.rb +0 -12
  142. data/doc/ex/gaussian_blur.rb +0 -11
  143. data/doc/ex/get_multiline_type_metrics.rb +0 -41
  144. data/doc/ex/get_pixels.rb +0 -47
  145. data/doc/ex/get_type_metrics.rb +0 -141
  146. data/doc/ex/gradientfill.rb +0 -27
  147. data/doc/ex/grav.rb +0 -45
  148. data/doc/ex/gravity.rb +0 -80
  149. data/doc/ex/group.rb +0 -26
  150. data/doc/ex/hatchfill.rb +0 -27
  151. data/doc/ex/image.rb +0 -44
  152. data/doc/ex/images/Apple.miff +0 -0
  153. data/doc/ex/images/Ballerina.jpg +0 -0
  154. data/doc/ex/images/Ballerina3.jpg +0 -0
  155. data/doc/ex/images/Button_0.gif +0 -0
  156. data/doc/ex/images/Button_1.gif +0 -0
  157. data/doc/ex/images/Button_2.gif +0 -0
  158. data/doc/ex/images/Button_3.gif +0 -0
  159. data/doc/ex/images/Button_4.gif +0 -0
  160. data/doc/ex/images/Button_5.gif +0 -0
  161. data/doc/ex/images/Button_6.gif +0 -0
  162. data/doc/ex/images/Button_7.gif +0 -0
  163. data/doc/ex/images/Button_8.gif +0 -0
  164. data/doc/ex/images/Button_9.gif +0 -0
  165. data/doc/ex/images/Button_A.gif +0 -0
  166. data/doc/ex/images/Button_B.gif +0 -0
  167. data/doc/ex/images/Button_C.gif +0 -0
  168. data/doc/ex/images/Button_D.gif +0 -0
  169. data/doc/ex/images/Button_E.gif +0 -0
  170. data/doc/ex/images/Button_F.gif +0 -0
  171. data/doc/ex/images/Button_G.gif +0 -0
  172. data/doc/ex/images/Button_H.gif +0 -0
  173. data/doc/ex/images/Button_I.gif +0 -0
  174. data/doc/ex/images/Button_J.gif +0 -0
  175. data/doc/ex/images/Button_K.gif +0 -0
  176. data/doc/ex/images/Button_L.gif +0 -0
  177. data/doc/ex/images/Button_M.gif +0 -0
  178. data/doc/ex/images/Button_N.gif +0 -0
  179. data/doc/ex/images/Button_O.gif +0 -0
  180. data/doc/ex/images/Button_P.gif +0 -0
  181. data/doc/ex/images/Button_Q.gif +0 -0
  182. data/doc/ex/images/Button_R.gif +0 -0
  183. data/doc/ex/images/Button_S.gif +0 -0
  184. data/doc/ex/images/Button_T.gif +0 -0
  185. data/doc/ex/images/Button_U.gif +0 -0
  186. data/doc/ex/images/Button_V.gif +0 -0
  187. data/doc/ex/images/Button_W.gif +0 -0
  188. data/doc/ex/images/Button_X.gif +0 -0
  189. data/doc/ex/images/Button_Y.gif +0 -0
  190. data/doc/ex/images/Button_Z.gif +0 -0
  191. data/doc/ex/images/Cheetah.jpg +0 -0
  192. data/doc/ex/images/Coffee.wmf +0 -0
  193. data/doc/ex/images/Flower_Hat.jpg +0 -0
  194. data/doc/ex/images/Gold_Statue.jpg +0 -0
  195. data/doc/ex/images/Hot_Air_Balloons.jpg +0 -0
  196. data/doc/ex/images/Hot_Air_Balloons_H.jpg +0 -0
  197. data/doc/ex/images/Leaf.miff +0 -0
  198. data/doc/ex/images/No.wmf +0 -0
  199. data/doc/ex/images/Polynesia.jpg +0 -0
  200. data/doc/ex/images/Red_Rocks.jpg +0 -0
  201. data/doc/ex/images/Rocks_On_Beach.miff +0 -0
  202. data/doc/ex/images/Shorts.jpg +0 -0
  203. data/doc/ex/images/Snake.wmf +0 -0
  204. data/doc/ex/images/Violin.jpg +0 -0
  205. data/doc/ex/images/Yellow_Rose.miff +0 -0
  206. data/doc/ex/images/big-duck.gif +0 -0
  207. data/doc/ex/images/duck.gif +0 -0
  208. data/doc/ex/images/duck0.gif +0 -0
  209. data/doc/ex/images/duck1.gif +0 -0
  210. data/doc/ex/images/duck10.gif +0 -0
  211. data/doc/ex/images/duck11.gif +0 -0
  212. data/doc/ex/images/duck12.gif +0 -0
  213. data/doc/ex/images/duck13.gif +0 -0
  214. data/doc/ex/images/duck14.gif +0 -0
  215. data/doc/ex/images/duck15.gif +0 -0
  216. data/doc/ex/images/duck2.gif +0 -0
  217. data/doc/ex/images/duck3.gif +0 -0
  218. data/doc/ex/images/duck4.gif +0 -0
  219. data/doc/ex/images/duck5.gif +0 -0
  220. data/doc/ex/images/duck6.gif +0 -0
  221. data/doc/ex/images/duck7.gif +0 -0
  222. data/doc/ex/images/duck8.gif +0 -0
  223. data/doc/ex/images/duck9.gif +0 -0
  224. data/doc/ex/images/graydient230x6.gif +0 -0
  225. data/doc/ex/images/image_with_profile.jpg +0 -0
  226. data/doc/ex/images/logo400x83.gif +0 -0
  227. data/doc/ex/images/model.miff +0 -0
  228. data/doc/ex/images/notimplemented.gif +0 -0
  229. data/doc/ex/images/smile.miff +0 -0
  230. data/doc/ex/images/spin.gif +0 -0
  231. data/doc/ex/implode.rb +0 -34
  232. data/doc/ex/level.rb +0 -11
  233. data/doc/ex/level_colors.rb +0 -11
  234. data/doc/ex/line.rb +0 -41
  235. data/doc/ex/line01.rb +0 -21
  236. data/doc/ex/mask.rb +0 -35
  237. data/doc/ex/matte_fill_to_border.rb +0 -39
  238. data/doc/ex/matte_floodfill.rb +0 -32
  239. data/doc/ex/matte_replace.rb +0 -39
  240. data/doc/ex/median_filter.rb +0 -28
  241. data/doc/ex/modulate.rb +0 -11
  242. data/doc/ex/mono.rb +0 -23
  243. data/doc/ex/morph.rb +0 -25
  244. data/doc/ex/mosaic.rb +0 -35
  245. data/doc/ex/motion_blur.rb +0 -11
  246. data/doc/ex/negate.rb +0 -11
  247. data/doc/ex/negate_channel.rb +0 -9
  248. data/doc/ex/nested_rvg.rb +0 -21
  249. data/doc/ex/nonzero.rb +0 -42
  250. data/doc/ex/normalize.rb +0 -11
  251. data/doc/ex/oil_paint.rb +0 -11
  252. data/doc/ex/opacity.rb +0 -37
  253. data/doc/ex/ordered_dither.rb +0 -11
  254. data/doc/ex/path.rb +0 -63
  255. data/doc/ex/pattern1.rb +0 -25
  256. data/doc/ex/pattern2.rb +0 -26
  257. data/doc/ex/polaroid.rb +0 -27
  258. data/doc/ex/polygon.rb +0 -23
  259. data/doc/ex/polygon01.rb +0 -21
  260. data/doc/ex/polyline.rb +0 -22
  261. data/doc/ex/polyline01.rb +0 -21
  262. data/doc/ex/posterize.rb +0 -8
  263. data/doc/ex/preview.rb +0 -8
  264. data/doc/ex/qbezierpath.rb +0 -52
  265. data/doc/ex/quad01.rb +0 -34
  266. data/doc/ex/quantize-m.rb +0 -25
  267. data/doc/ex/radial_blur.rb +0 -9
  268. data/doc/ex/raise.rb +0 -8
  269. data/doc/ex/random_threshold_channel.rb +0 -13
  270. data/doc/ex/rect01.rb +0 -14
  271. data/doc/ex/rect02.rb +0 -20
  272. data/doc/ex/rectangle.rb +0 -34
  273. data/doc/ex/reduce_noise.rb +0 -28
  274. data/doc/ex/remap.rb +0 -11
  275. data/doc/ex/remap_images.rb +0 -19
  276. data/doc/ex/resize_to_fill.rb +0 -8
  277. data/doc/ex/resize_to_fit.rb +0 -8
  278. data/doc/ex/roll.rb +0 -9
  279. data/doc/ex/rotate.rb +0 -44
  280. data/doc/ex/rotate_f.rb +0 -14
  281. data/doc/ex/roundrect.rb +0 -33
  282. data/doc/ex/rubyname.rb +0 -30
  283. data/doc/ex/rvg_clippath.rb +0 -12
  284. data/doc/ex/rvg_linecap.rb +0 -42
  285. data/doc/ex/rvg_linejoin.rb +0 -40
  286. data/doc/ex/rvg_opacity.rb +0 -18
  287. data/doc/ex/rvg_pattern.rb +0 -26
  288. data/doc/ex/rvg_stroke_dasharray.rb +0 -11
  289. data/doc/ex/segment.rb +0 -11
  290. data/doc/ex/sepiatone.rb +0 -7
  291. data/doc/ex/shade.rb +0 -11
  292. data/doc/ex/shadow.rb +0 -30
  293. data/doc/ex/shave.rb +0 -15
  294. data/doc/ex/shear.rb +0 -10
  295. data/doc/ex/sketch.rb +0 -17
  296. data/doc/ex/skewx.rb +0 -51
  297. data/doc/ex/skewy.rb +0 -47
  298. data/doc/ex/smile.rb +0 -125
  299. data/doc/ex/solarize.rb +0 -11
  300. data/doc/ex/sparse_color.rb +0 -54
  301. data/doc/ex/splice.rb +0 -8
  302. data/doc/ex/spread.rb +0 -11
  303. data/doc/ex/stegano.rb +0 -55
  304. data/doc/ex/stroke_dasharray.rb +0 -42
  305. data/doc/ex/stroke_fill.rb +0 -10
  306. data/doc/ex/stroke_linecap.rb +0 -44
  307. data/doc/ex/stroke_linejoin.rb +0 -48
  308. data/doc/ex/stroke_width.rb +0 -49
  309. data/doc/ex/swirl.rb +0 -17
  310. data/doc/ex/text.rb +0 -37
  311. data/doc/ex/text01.rb +0 -16
  312. data/doc/ex/text_align.rb +0 -36
  313. data/doc/ex/text_antialias.rb +0 -37
  314. data/doc/ex/text_styles.rb +0 -19
  315. data/doc/ex/text_undercolor.rb +0 -28
  316. data/doc/ex/texture_fill_to_border.rb +0 -34
  317. data/doc/ex/texture_floodfill.rb +0 -32
  318. data/doc/ex/texturefill.rb +0 -24
  319. data/doc/ex/threshold.rb +0 -13
  320. data/doc/ex/to_blob.rb +0 -13
  321. data/doc/ex/translate.rb +0 -39
  322. data/doc/ex/transparent.rb +0 -38
  323. data/doc/ex/transpose.rb +0 -9
  324. data/doc/ex/transverse.rb +0 -9
  325. data/doc/ex/tref01.rb +0 -24
  326. data/doc/ex/triangle01.rb +0 -15
  327. data/doc/ex/trim.rb +0 -23
  328. data/doc/ex/tspan01.rb +0 -17
  329. data/doc/ex/tspan02.rb +0 -17
  330. data/doc/ex/tspan03.rb +0 -19
  331. data/doc/ex/unsharp_mask.rb +0 -28
  332. data/doc/ex/viewex.rb +0 -33
  333. data/doc/ex/vignette.rb +0 -12
  334. data/doc/ex/watermark.rb +0 -27
  335. data/doc/ex/wave.rb +0 -9
  336. data/doc/ex/wet_floor.rb +0 -58
  337. data/doc/ex/writing_mode01.rb +0 -26
  338. data/doc/ex/writing_mode02.rb +0 -26
  339. data/doc/ilist.html +0 -2056
  340. data/doc/image1.html +0 -4680
  341. data/doc/image2.html +0 -3665
  342. data/doc/image3.html +0 -4522
  343. data/doc/imageattrs.html +0 -1638
  344. data/doc/imusage.html +0 -514
  345. data/doc/index.html +0 -416
  346. data/doc/info.html +0 -1499
  347. data/doc/magick.html +0 -565
  348. data/doc/optequiv.html +0 -2435
  349. data/doc/rvg.html +0 -975
  350. data/doc/rvgclip.html +0 -248
  351. data/doc/rvggroup.html +0 -305
  352. data/doc/rvgimage.html +0 -289
  353. data/doc/rvgpattern.html +0 -475
  354. data/doc/rvgshape.html +0 -406
  355. data/doc/rvgstyle.html +0 -270
  356. data/doc/rvgtext.html +0 -465
  357. data/doc/rvgtspan.html +0 -238
  358. data/doc/rvgtut.html +0 -530
  359. data/doc/rvguse.html +0 -145
  360. data/doc/rvgxform.html +0 -294
  361. data/doc/scripts/doc.js +0 -22
  362. data/doc/scripts/stripeTables.js +0 -23
  363. data/doc/struct.html +0 -1339
  364. data/doc/usage.html +0 -1621
  365. data/examples/constitute.rb +0 -7
  366. data/examples/crop_with_gravity.rb +0 -42
  367. data/examples/demo.rb +0 -324
  368. data/examples/describe.rb +0 -43
  369. data/examples/find_similar_region.rb +0 -34
  370. data/examples/histogram.rb +0 -321
  371. data/examples/identify.rb +0 -185
  372. data/examples/image_opacity.rb +0 -29
  373. data/examples/import_export.rb +0 -31
  374. data/examples/pattern_fill.rb +0 -38
  375. data/examples/rotating_text.rb +0 -44
  376. data/examples/spinner.rb +0 -49
  377. data/examples/thumbnail.rb +0 -64
  378. data/examples/vignette.rb +0 -78
  379. data/spec/rmagick/ImageList1_spec.rb +0 -24
  380. data/spec/rmagick/draw_spec.rb +0 -156
  381. data/spec/rmagick/image/blue_shift_spec.rb +0 -16
  382. data/spec/rmagick/image/composite_spec.rb +0 -140
  383. data/spec/rmagick/image/constitute_spec.rb +0 -15
  384. data/spec/rmagick/image/dispatch_spec.rb +0 -18
  385. data/spec/rmagick/image/from_blob_spec.rb +0 -14
  386. data/spec/rmagick/image/ping_spec.rb +0 -14
  387. data/spec/rmagick/image/properties_spec.rb +0 -29
  388. data/spec/spec_helper.rb +0 -4
  389. data/test/Image1.rb +0 -565
  390. data/test/Image2.rb +0 -1304
  391. data/test/Image3.rb +0 -1030
  392. data/test/ImageList1.rb +0 -806
  393. data/test/ImageList2.rb +0 -385
  394. data/test/Image_attributes.rb +0 -697
  395. data/test/Import_Export.rb +0 -121
  396. data/test/Info.rb +0 -345
  397. data/test/Magick.rb +0 -321
  398. data/test/Pixel.rb +0 -116
  399. data/test/Preview.rb +0 -57
  400. data/test/cmyk.icm +0 -0
  401. data/test/srgb.icm +0 -0
  402. data/test/test_all_basic.rb +0 -38
  403. data/test/tmpnam_test.rb +0 -50
  404. data/wercker.yml +0 -10
data/test/Image3.rb DELETED
@@ -1,1030 +0,0 @@
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