summaryrefslogtreecommitdiff
path: root/spec/ruby/library/prime/integer/prime_division_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/ruby/library/prime/integer/prime_division_spec.rb')
-rw-r--r--spec/ruby/library/prime/integer/prime_division_spec.rb19
1 files changed, 19 insertions, 0 deletions
diff --git a/spec/ruby/library/prime/integer/prime_division_spec.rb b/spec/ruby/library/prime/integer/prime_division_spec.rb
new file mode 100644
index 0000000000..5631b22d0a
--- /dev/null
+++ b/spec/ruby/library/prime/integer/prime_division_spec.rb
@@ -0,0 +1,19 @@
+require_relative '../../../spec_helper'
+require 'prime'
+
+describe "Integer#prime_division" do
+ it "returns an array of a prime factor and a corresponding exponent" do
+ (2*3*5*7*11*13*17).prime_division.should ==
+ [[2,1], [3,1], [5,1], [7,1], [11,1], [13,1], [17,1]]
+ end
+
+ it "returns an empty array for 1" do
+ 1.prime_division.should == []
+ end
+ it "returns an empty array for -1" do
+ -1.prime_division.should == [[-1, 1]]
+ end
+ it "raises ZeroDivisionError for 0" do
+ -> { 0.prime_division }.should.raise(ZeroDivisionError)
+ end
+end