aboutsummaryrefslogtreecommitdiffstats
path: root/spec/rubyspec/library/matrix/permutation_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/rubyspec/library/matrix/permutation_spec.rb')
-rw-r--r--spec/rubyspec/library/matrix/permutation_spec.rb32
1 files changed, 32 insertions, 0 deletions
diff --git a/spec/rubyspec/library/matrix/permutation_spec.rb b/spec/rubyspec/library/matrix/permutation_spec.rb
new file mode 100644
index 0000000000..7098c46015
--- /dev/null
+++ b/spec/rubyspec/library/matrix/permutation_spec.rb
@@ -0,0 +1,32 @@
+require File.expand_path('../../../spec_helper', __FILE__)
+require 'matrix'
+
+describe "Matrix#permutation?" do
+ it "returns true for a permutation Matrix" do
+ Matrix[[0, 1, 0], [0, 0, 1], [1, 0, 0]].permutation?.should be_true
+ end
+
+ it "returns false for a non permutation square Matrix" do
+ Matrix[[0, 1], [0, 0]].permutation?.should be_false
+ Matrix[[-1, 0], [0, -1]].permutation?.should be_false
+ Matrix[[1, 0], [1, 0]].permutation?.should be_false
+ Matrix[[1, 0], [1, 1]].permutation?.should be_false
+ end
+
+ it "returns true for an empty 0x0 matrix" do
+ Matrix.empty(0,0).permutation?.should be_true
+ end
+
+ it "raises an error for rectangular matrices" do
+ [
+ Matrix[[0], [0]],
+ Matrix[[0, 0]],
+ Matrix.empty(0, 2),
+ Matrix.empty(2, 0),
+ ].each do |rectangual_matrix|
+ lambda {
+ rectangual_matrix.permutation?
+ }.should raise_error(Matrix::ErrDimensionMismatch)
+ end
+ end
+end