Quick update on the below error... 

I dropped into the #puppet-dev IRC channel, and was able to resolve the 
issue with some assistance from Dominic, so many thanks for that... 

Latest code has been committed to Git, but basically I was missing a couple 
of requires for Puppet libs... 

Now happily creating volumes and qtrees in the same run. 
Onwards to the next functionality requirement now... Exports :D

Cheers
Gav

On Wednesday, 7 November 2012 16:28:46 UTC, Gavin Williams wrote:
>
> :( Seems to be one step forward and two steps back atm... 
>
> Following the successful creation and deletion of NetApp filer volumes 
> using puppet earlier in the day, I added the required provider and type to 
> support qtree creation and deletion... 
>
> However since then, I haven't been able to create either a new volume or a 
> new qtree reliably... 
> It seems that it will intermittently work, but the majority of the time 
> the puppet device run will fail with 
>
> Error: Could not retrieve catalog from remote server: Error 400 on SERVER: 
>> Could not autoload puppet/type/netapp_volume: Could not autoload 
>> puppet/provider/netapp_volume/netapp_volume: uninitialized constant 
>> Puppet::Util::NetworkDevice on node actint-star-nactl01
>>
>> This error alternates between provider/netapp_volume/netapp_volume and 
> provider/netapp_qtree/netapp_qtree... 
> It doesn't appear to be due to config, as I've stripped the node config 
> right back to base and still seeing errors... 
>
> The node config I was trying to work towards is: 
>
>>         netapp_qtree { 'q_puppet_test1':
>>                 ensure => present,
>>                 volume => 'v_puppet_test',
>>                 require => Netapp_volume['v_puppet_test1']
>>         }
>>
>>         netapp_volume { 'v_puppet_test1':
>>                 ensure => present,
>>                 initsize => "1t",
>>                 aggregate => "aggr01",
>>                 spaceres => "none",
>>         }
>>
>
> I've tried multiple agent runs, multiple master restarts, all to no 
> avail... 
>
> Any ideas on what could be the issue? 
>
> As always, latest code is available in Git... 
>
> Cheers
> Gavin 
>
>
> On Wednesday, 7 November 2012 12:06:17 UTC, Gavin Williams wrote:
>>
>> Quick update... It looks like all that was needed to resolve the below 
>> was a puppetmaster restart. 
>>
>> Have successfully managed to create a new volume on the NetApp filer 
>> using puppet :) :D
>>
>> Now to plough on with adding support for the rest of the bits we need :) 
>>
>> Cheers
>> Gavin 
>>
>> On Tuesday, 6 November 2012 17:40:34 UTC, Gavin Williams wrote:
>>>
>>> Scratch my last, had a bit of a eureka moment... 
>>>
>>> Added ':transport: to the attr_accessor against device.rb, and it 
>>> started working again... 
>>>
>>> However now failing elsewhere... 
>>> Have got the following against a relevant node:
>>>
>>>         # Test NetApp volume provider
>>>>         netapp_volume { 'v_puppet_test':
>>>>                 ensure => present,
>>>>                 initsize => "1g",
>>>>                 aggr => "aggr01",
>>>>                 spaceresv => "none",
>>>>         }
>>>>
>>>
>>> The run is failing with:
>>>
>>>>  Error: Could not retrieve catalog from remote server: Error 400 on 
>>>> SERVER: Invalid parameter aggr at /etc/puppet/manifests/site.pp:30 on node 
>>>> actint-star-nactl01
>>>> Error: Could not set 'present' on ensure: undefined method 
>>>> `result_reason' for #<NaElement:0x7ffb9cb5d160> at 
>>>> 27:/etc/puppet/manifests/site.pp
>>>> Error: Could not set 'present' on ensure: undefined method 
>>>> `result_reason' for #<NaElement:0x7ffb9cb5d160> at 
>>>> 27:/etc/puppet/manifests/site.pp
>>>> Wrapped exception:
>>>> undefined method `result_reason' for #<NaElement:0x7ffb9cb5d160>
>>>> Error: 
>>>> /Stage[main]//Node[actint-star-nactl01]/Netapp_volume[v_puppet_test]/ensure:
>>>>  
>>>> change from absent to present failed: Could not set 'present' on ensure: 
>>>> undefined method `result_reason' for #<NaElement:0x7ffb9cb5d160> at 
>>>> 27:/etc/puppet/manifests/site.pp
>>>>
>>>
>>>  Got some debug logging, which is giving:
>>>
>>>> ^[[0;36mDebug^[[0m: Puppet::Provider::Netapp_volume: checking existance 
>>>> of Netapp Volume v_puppet_test
>>>> ^[[0;36mDebug^[[0m: Puppet::Provider::Netapp_volume: Vol Info: <results 
>>>> status="failed" reason="No volume named 'v_puppet_test' exists" 
>>>> errno="13040"></results>
>>>>
>>>> ^[[0;36mDebug^[[0m: Puppet::Provider::Netapp_volume: Volume doesn't 
>>>> currently exist.
>>>> ^[[0;36mDebug^[[0m: Puppet::Provider::Netapp_volume: creating Netapp 
>>>> Volume v_puppet_test of initial size 1g
>>>>
>>>
>>> So I can see that the provider exists? is working correctly, and it's 
>>> trying to fire the create def... 
>>>
>>> The type is defined correctly afaik:
>>>
>>>> Puppet::Type.newtype(:netapp_volume) do 
>>>>   @doc = "Manage Netapp Volume creation, modification and deletion."
>>>>   
>>>>   apply_to_device
>>>>   
>>>>   ensurable do
>>>>     desc "Netapp Volume resource state. Valid values are: present, absent."
>>>>     
>>>>     defaultto(:present)
>>>>     
>>>>     newvalue(:present) do 
>>>>       provider.create
>>>>     end
>>>>     
>>>>     newvalue(:absent) do 
>>>>       provider.destroy
>>>>     end
>>>>   end
>>>>   
>>>>   newparam(:name) do
>>>>     desc "The volume name."
>>>>     isnamevar
>>>>     #newvalues(/^[[:alpha:][:digit:]\.]+$/)
>>>>   end
>>>>
>>>>   newparam(:initsize) do
>>>>     desc "The initial volume size."
>>>>     defaultto "1g"
>>>>      
>>>>   end
>>>>   
>>>>   newparam(:aggr) do
>>>>     desc "The aggregate this volume should be created in." 
>>>>     
>>>>   end
>>>>   
>>>>   newparam(:spaceresv) do
>>>>     desc "The space reservation mode."
>>>>     
>>>>   end
>>>> end
>>>>
>>>>
>>> Latest code in Git...  
>>>
>>> Any ideas? 
>>>
>>> Cheers
>>> Gavin 
>>>
>>> On Monday, 5 November 2012 17:46:07 UTC, Gavin Williams wrote:
>>>>
>>>> Looks like the below error was caused by some locally cached code that 
>>>> hadn't been updated by my Git pull :s
>>>>
>>>> Resolved that, and now am getting the following:
>>>>
>>>> $ sudo puppet device -v
>>>>> Info: starting applying configuration to actint-star-nactl01 at 
>>>>> actint-star-nactl01
>>>>> Warning: Local environment: "production" doesn't match server 
>>>>> specified node environment "development", switching agent to 
>>>>> "development".
>>>>> Info: Retrieving plugin
>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet]/mode: 
>>>>> mode changed '0775' to '0755'
>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet/provider]/mode:
>>>>>  
>>>>> mode changed '0775' to '0755'
>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet/provider/netapp.rb]/content:
>>>>>  
>>>>> content changed '{md5}399796914d8aeb68387455de5b24f735' to 
>>>>> '{md5}3be2121ab99116c4bc89db21d5d4b54b'
>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet/provider/netapp_volume/netapp_volume.rb]/content:
>>>>>  
>>>>> content changed '{md5}46b2a0004e0245c577974e7a645e08f7' to 
>>>>> '{md5}1b06628868826a8ea64744a7ae8ec8da'
>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet/type]/mode: 
>>>>> mode changed '0775' to '0755'
>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet/type/netapp_volume.rb]/content:
>>>>>  
>>>>> content changed '{md5}ebe14c73783c97063d9b6ae0bc791896' to 
>>>>> '{md5}2fb244482c7d760e6cc132f104be619d'
>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet/util/network_device/netapp/facts.rb]/content:
>>>>>  
>>>>> content changed '{md5}c7e59e79e19486cba9ae7e5314b2a061' to 
>>>>> '{md5}b0c912dc663d5251219bbad895455834'
>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet/util/network_device/netapp/device.rb]/content:
>>>>>  
>>>>> content changed '{md5}7354a748bd41582fcf76bf2643098fcd' to 
>>>>> '{md5}9d2e26f97c7ea6ea16177acb8df85714'
>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet/util/network_device/netapp/NaServer.rb]/content:
>>>>>  
>>>>> content changed '{md5}cd815964f9a2dfe757f5365a848b80d5' to 
>>>>> '{md5}63f12abed9d1145b6d326c9fc06eb0c0'
>>>>> Info: Caching catalog for actint-star-nactl01
>>>>> Info: Applying configuration version '1352132516'
>>>>> Error: 
>>>>> /Stage[main]//Node[actint-star-nactl01]/Netapp_volume[v_puppet_test]: 
>>>>> Could 
>>>>> not evaluate: undefined method `transport' for 
>>>>> #<Puppet::Util::NetworkDevice::Netapp::Device:0x7ff3142c80f8>
>>>>> Finished catalog run in 0.11 seconds
>>>>>
>>>>
>>>> If I change *provider/netapp_volume/netapp_volume.rb *as follows*:*
>>>>
>>>>>
>>>>> /File[/var/lib/puppet/lib/puppet/provider/netapp_volume/netapp_volume.rb]/content:
>>>>> --- 
>>>>> /var/lib/puppet/lib/puppet/provider/netapp_volume/netapp_volume.rb  
>>>>> 2012-11-05 17:26:56.257616498 +0000
>>>>> +++ /tmp/puppet-file20121105-8521-10tepn6-0     2012-11-05 
>>>>> 17:40:16.440612301 +0000
>>>>> @@ -19,7 +19,7 @@
>>>>>
>>>>>    def exists?
>>>>>      Puppet.debug("Puppet::Provider::Netapp_volume: checking existance 
>>>>> of Netapp Volume #{resource[:name]}")
>>>>> -    transport.invoke("volume-list-info").include?(resource[:name])
>>>>> +    @transport.invoke("volume-list-info").include?(resource[:name])
>>>>>    end
>>>>>
>>>> I get:
>>>>
>>>>>  Info: starting applying configuration to actint-star-nactl01 at 
>>>>> actint-star-nactl01
>>>>> Warning: Local environment: "production" doesn't match server 
>>>>> specified node environment "development", switching agent to 
>>>>> "development".
>>>>> Info: Retrieving plugin
>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet/provider/netapp_volume/netapp_volume.rb]/content:
>>>>>  
>>>>> content changed '{md5}1b06628868826a8ea64744a7ae8ec8da' to 
>>>>> '{md5}feb535835cefd0921c8be5d0af6e11f2'
>>>>> Info: Caching catalog for actint-star-nactl01
>>>>> Info: Applying configuration version '1352132516'
>>>>> Error: 
>>>>> /Stage[main]//Node[actint-star-nactl01]/Netapp_volume[v_puppet_test]: 
>>>>> Could 
>>>>> not evaluate: undefined method `invoke' for nil:NilClass
>>>>> Finished catalog run in 0.20 seconds
>>>>>
>>>>
>>>> So not sure why it's not working either way... 
>>>>
>>>> Any ideas???
>>>>
>>>> Cheers
>>>> Gavin  
>>>>  
>>>>
>>>> On Monday, 5 November 2012 16:44:15 UTC, Gavin Williams wrote:
>>>>>
>>>>> Ok, moving on then... 
>>>>>
>>>>> I've created a 'netapp_volume' type and provider, and am trying to 
>>>>> test it against one of the existing NetApp device nodes:
>>>>> *manifests/site.pp* contains:
>>>>>
>>>>> node 'actint-star-nactl01' {
>>>>>>
>>>>>>         # Test NetApp volume provider
>>>>>>         netapp_volume { 'v_puppet_test':
>>>>>>                 ensure => present,
>>>>>>         }
>>>>>>
>>>>>> }
>>>>>>
>>>>>>
>>>>> When running *'puppet device -v'*, I get:
>>>>>
>>>>>> $ sudo puppet device -v
>>>>>> Info: starting applying configuration to actint-star-nactl01 at 
>>>>>> actint-star-nactl01
>>>>>> Warning: Local environment: "production" doesn't match server 
>>>>>> specified node environment "development", switching agent to 
>>>>>> "development".
>>>>>> Info: Retrieving plugin
>>>>>> /File[/var/lib/puppet/devices/actint-star-nactl01/lib/puppet/type/netapp_volume.rb]/content:
>>>>>>  
>>>>>> content changed '{md5}2f3e20a3878f9ed94a5fffc4a9811ef7' to 
>>>>>> '{md5}ebe14c73783c97063d9b6ae0bc791896'
>>>>>> Error: Could not autoload 
>>>>>> puppet/provider/netapp_volume/netapp_volume: uninitialized constant 
>>>>>> Puppet::Provider::Netapp
>>>>>> Error: Could not autoload puppet/type/netapp_volume: Could not 
>>>>>> autoload puppet/provider/netapp_volume/netapp_volume: uninitialized 
>>>>>> constant Puppet::Provider::Netapp
>>>>>> Error: Could not retrieve catalog from remote server: Could not 
>>>>>> intern from pson: Could not autoload puppet/type/netapp_volume: Could 
>>>>>> not 
>>>>>> autoload puppet/provider/netapp_volume/netapp_volume: uninitialized 
>>>>>> constant Puppet::Provider::Netapp
>>>>>> Using cached catalog
>>>>>> Info: Applying configuration version '1352132516'
>>>>>> Error: 
>>>>>> /Stage[main]//Node[actint-star-nactl01]/Netapp_volume[v_puppet_test]: 
>>>>>> Could 
>>>>>> not evaluate: No ability to determine if netapp_volume exists
>>>>>> Finished catalog run in 0.21 seconds
>>>>>>
>>>>>>
>>>>> So it's failing to autoload my new provider, however I'm not sure what 
>>>>> 'uninitialised constant' means :s 
>>>>> The class *Puppet::Provider::Netapp* is defined in *
>>>>> lib/puppet/provider/netapp.rb*. 
>>>>>
>>>>> I've pushed the latest edits into 
>>>>> Github<https://github.com/fatmcgav/fatmcgav-netapp>. 
>>>>>
>>>>>
>>>>> Ideas welcome. 
>>>>>
>>>>> Cheers
>>>>> Gavin 
>>>>>
>>>>> On Monday, 5 November 2012 15:26:08 UTC, Gavin Williams wrote:
>>>>>>
>>>>>> Me again... 
>>>>>>
>>>>>> I pressed on using the /var/lib/puppet... configdir for the 
>>>>>> time-being, and with a bit more jiggery pokery, I've managed to 
>>>>>> successfully register a NetApp device, and extract some facts from it... 
>>>>>> And here's the photographic proof :) :D http://ow.ly/i/15SLN
>>>>>>
>>>>>> Now to start looking at how to handle the next steps, such as volume 
>>>>>> creation, quota creation, export creation... :D
>>>>>>
>>>>>> Latest code has been pushed to 
>>>>>> Github<https://github.com/fatmcgav/fatmcgav-netapp>
>>>>>> ...
>>>>>>
>>>>>> Still need to work out how to use a central confdir rather than agent 
>>>>>> specific ones, but can come back to that :) 
>>>>>>
>>>>>> Cheers
>>>>>> Gavin 
>>>>>>
>>>>>> On Monday, 5 November 2012 11:35:26 UTC, Gavin Williams wrote:
>>>>>>>
>>>>>>> Ok, have fixed that error aswell... 
>>>>>>>
>>>>>>> Replaced *':configdir' *with *':confdir'*. 
>>>>>>> However it's now failing due to the netapp.yml file not being 
>>>>>>> present... What's confused me is the path it's come up with for *
>>>>>>> ':confdir'*. According to the debug output, it's trying to use 
>>>>>>>
>>>>>>> ESC[0;36mDebugESC[0m: Puppet::Device::Netapp: connecting to Netapp 
>>>>>>>> device actint-star-nactl01.
>>>>>>>> ESC[0;36mDebugESC[0m: Puppet::Device::Netapp: configdir is 
>>>>>>>> /var/lib/puppet/devices/actint-star-nactl01.
>>>>>>>>
>>>>>>>
>>>>>>> However I would prefer it to use */etc/puppet* on the master...  
>>>>>>> Any way I could do this, other than hard-coding? 
>>>>>>>
>>>>>>> Cheers
>>>>>>> Gavin
>>>>>>>
>>>>>>> On Monday, 5 November 2012 11:24:16 UTC, Gavin Williams wrote:
>>>>>>>>
>>>>>>>> Ok, after a bit more googling, have solved the NaElement load 
>>>>>>>> error... 
>>>>>>>>
>>>>>>>> Tweaked the NaServer.rb file as follows:
>>>>>>>>
>>>>>>>> #require 'NaElement'
>>>>>>>>> require File.dirname(__FILE__) + "/NaElement"
>>>>>>>>>
>>>>>>>>
>>>>>>>> I've now successfully loaded the require Netapp SDK files, and 
>>>>>>>> started working through the connection process...
>>>>>>>> Though it looks like it's hit another error:
>>>>>>>>
>>>>>>>> Debug: Puppet::Device::Netapp: connecting to Netapp device 
>>>>>>>>> actint-star-nactl01.
>>>>>>>>> Debug: Puppet::Device::Netapp: configdir is .
>>>>>>>>> Error: Can't load netapp for actint-star-nactl01: undefined method 
>>>>>>>>> `+' for nil:NilClass
>>>>>>>>>
>>>>>>>>
>>>>>>>> Tracked the above back to *device.rb*, where it's attempting to 
>>>>>>>> use *'Puppet[:configdir]'* but is failing to find the value... 
>>>>>>>>
>>>>>>>> So now to work out what's going on there :) 
>>>>>>>>
>>>>>>>> Cheers
>>>>>>>> Gav
>>>>>>>>
>>>>>>>> On Monday, 5 November 2012 10:47:56 UTC, Gavin Williams wrote:
>>>>>>>>>
>>>>>>>>> Hi all
>>>>>>>>>
>>>>>>>>> Following on from my previous post Puppet Network 
>>>>>>>>> Devices..<https://groups.google.com/forum/?fromgroups=#!topic/puppet-users/fuXshtYmhhk>I've
>>>>>>>>>  now started work on creating a NetApp network device provider for 
>>>>>>>>> Puppet... 
>>>>>>>>>
>>>>>>>>> I'm trying to start simply by just gathering some facts from our 
>>>>>>>>> filers. 
>>>>>>>>>
>>>>>>>>> The code soo far is available here: 
>>>>>>>>> https://github.com/fatmcgav/shrug-netapp/ Credit to the original 
>>>>>>>>> author shrug for setting out the framework... 
>>>>>>>>>
>>>>>>>>> Anyhow, onto my first challenge. 
>>>>>>>>>
>>>>>>>>> I've downloaded and added the relevant NetApp SDK files into *
>>>>>>>>> modules/shrug-netapp/lib/puppet/util/network_device/netapp/* as 
>>>>>>>>> shown below:
>>>>>>>>>
>>>>>>>>> $ ls -l modules/shrug-netapp/lib/puppet/util/network_device/netapp/
>>>>>>>>>> total 88
>>>>>>>>>> -rw-r--r--. 1 puppet puppet   924 Nov  2 17:13 device.rb
>>>>>>>>>> -rw-r--r--. 1 puppet puppet  8229 Nov  2 17:16 DfmErrno.rb
>>>>>>>>>> -rw-r--r--. 1 puppet puppet   228 Nov  2 17:00 facts.rb
>>>>>>>>>> -rw-r--r--. 1 puppet puppet  9451 Nov  2 17:16 NaElement.rb
>>>>>>>>>> -rw-r--r--. 1 puppet puppet 36089 Nov  2 17:15 NaErrno.rb
>>>>>>>>>> -rw-r--r--. 1 puppet puppet 19036 Nov  2 17:15 NaServer.rb
>>>>>>>>>>
>>>>>>>>>  
>>>>>>>>> The NaServer class is then included within the device.rb file 
>>>>>>>>> above. 
>>>>>>>>> However Puppet is currently failing with:
>>>>>>>>>
>>>>>>>>>> Info: starting applying configuration to actint-star-nactl01 at 
>>>>>>>>>> actint-star-nactl01
>>>>>>>>>> Error: Could not run: no such file to load -- NaElement
>>>>>>>>>>
>>>>>>>>>
>>>>>>>>> This NaElement file is require'd by the NaServer class. 
>>>>>>>>> However it seems to be failing due to the include path not 
>>>>>>>>> including the NaElement.rb file... 
>>>>>>>>> Therefore I'm guessing that Puppet/Ruby is looking for the 
>>>>>>>>> NaElement file in some default location, rather than the same 
>>>>>>>>> location as 
>>>>>>>>> the NaServer class... 
>>>>>>>>>
>>>>>>>>> I've generated the same error on some tests scripts by moving the 
>>>>>>>>> NetApp SDK files into a sdk sub folder, and then just *"require 
>>>>>>>>> sdk/NaServer"* in my script, which generates a very similar error:
>>>>>>>>>
>>>>>>>>>> ruby hello_ontapi.rb  192.168.35.118 root xxx
>>>>>>>>>> ./sdk/NaServer.rb:21:in `require': no such file to load -- 
>>>>>>>>>> NaElement (LoadError)
>>>>>>>>>>         from ./sdk/NaServer.rb:21
>>>>>>>>>>         from hello_ontapi.rb:24:in `require'
>>>>>>>>>>         from hello_ontapi.rb:24
>>>>>>>>>>
>>>>>>>>>
>>>>>>>>> Any ideas how I could work around this? 
>>>>>>>>>
>>>>>>>>> Cheers
>>>>>>>>> Gavin 
>>>>>>>>>  
>>>>>>>>>
>>>>>>>>

-- 
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To view this discussion on the web visit 
https://groups.google.com/d/msg/puppet-users/-/sow60HSKww0J.
To post to this group, send email to puppet-users@googlegroups.com.
To unsubscribe from this group, send email to 
puppet-users+unsubscr...@googlegroups.com.
For more options, visit this group at 
http://groups.google.com/group/puppet-users?hl=en.

Reply via email to