summaryrefslogtreecommitdiff
path: root/spec/rubyspec/library/win32ole/win32ole/new_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/rubyspec/library/win32ole/win32ole/new_spec.rb')
-rw-r--r--spec/rubyspec/library/win32ole/win32ole/new_spec.rb27
1 files changed, 27 insertions, 0 deletions
diff --git a/spec/rubyspec/library/win32ole/win32ole/new_spec.rb b/spec/rubyspec/library/win32ole/win32ole/new_spec.rb
new file mode 100644
index 0000000000..78f141b608
--- /dev/null
+++ b/spec/rubyspec/library/win32ole/win32ole/new_spec.rb
@@ -0,0 +1,27 @@
+require File.expand_path('../../fixtures/classes', __FILE__)
+
+platform_is :windows do
+ require 'win32ole'
+
+ describe "WIN32OLESpecs.new_ole" do
+ it "creates a WIN32OLE object from OLE server name" do
+ shell = WIN32OLESpecs.new_ole 'Shell.Application'
+ shell.should be_kind_of WIN32OLE
+ end
+
+ it "creates a WIN32OLE object from valid CLSID" do
+ shell = WIN32OLESpecs.new_ole("{13709620-C279-11CE-A49E-444553540000}")
+ shell.should be_kind_of WIN32OLE
+ end
+
+ it "raises TypeError if argument cannot be converted to String" do
+ lambda { WIN32OLESpecs.new_ole(42) }.should raise_error( TypeError )
+ end
+
+ it "raises WIN32OLERuntimeError if invalid string is given" do
+ lambda { WIN32OLESpecs.new_ole('foo') }.should raise_error( WIN32OLERuntimeError )
+ end
+
+ end
+
+end