Skip to content
This repository was archived by the owner on Jul 14, 2021. It is now read-only.

ChefDK's chef generate command fails with Insufficient permissions after cd'ing to a different directory #340

Closed
FilBot3 opened this issue Mar 25, 2015 · 6 comments
Assignees
Labels
Platform: Windows Type: Bug Doesn't work as expected.

Comments

@FilBot3
Copy link

FilBot3 commented Mar 25, 2015

For some reason, when I cd to a different directory after opening Command Prompt or PowerShell, I receive an error saying that I don't have sufficient permissions.

C:\Users\user01
λ cd Desktop\

C:\Users\user01\Desktop                                                                                                                                                                                                                     
λ chef generate cookbook thisiscool                                                                                                                                                                                                           
Compiling Cookbooks...                                                                                                                                                                                                                        
Recipe: code_generator::cookbook                                                                                                                                                                                                              
  * directory[C:/Users/user01/Desktop/thisiscool] action create                                                                                                                                                                             
    * Cannot create directory[C:/Users/user01/Desktop/thisiscool] at C:/Users/user01/Desktop/thisiscool due to insufficient permissions                                                                                                   
    ================================================================================                                                                                                                                                          
    Error executing action `create` on resource 'directory[C:/Users/user01/Desktop/thisiscool]'                                                                                                                                             
    ================================================================================                                                                                                                                                          

    Chef::Exceptions::InsufficientPermissions                                                                                                                                                                                                 
    -----------------------------------------                                                                                                                                                                                                 
    Cannot create directory[C:/Users/user01/Desktop/thisiscool] at C:/Users/user01/Desktop/thisiscool due to insufficient permissions                                                                                                     

    Resource Declaration:                                                                                                                                                                                                                     
    ---------------------                                                                                                                                                                                                                     
    # In C:\opscode\chefdk\embedded\apps\chef-dk\lib\chef-dk\skeletons\code_generator\recipes\cookbook.rb                                                                                                                                     

      1:                                                                                                                                                                                                                                      
      2: context = ChefDK::Generator.context                                                                                                                                                                                                  

    Compiled Resource:                                                                                                                                                                                                                        
    ------------------                                                                                                                                                                                                                        
    # Declared in C:\opscode\chefdk\embedded\apps\chef-dk\lib\chef-dk\skeletons\code_generator\recipes\cookbook.rb:6:in `from_file'                                                                                                           

    directory("C:/Users/user01/Desktop/thisiscool") do                                                                                                                                                                                      
      action :create                                                                                                                                                                                                                          
      retries 0                                                                                                                                                                                                                               
      retry_delay 2                                                                                                                                                                                                                           
      default_guard_interpreter :default                                                                                                                                                                                                      
      path "C:/Users/user01/Desktop/thisiscool"                                                                                                                                                                                             
      declared_type :directory                                                                                                                                                                                                                
      cookbook_name :code_generator                                                                                                                                                                                                           
      recipe_name "cookbook"                                                                                                                                                                                                                  
    end                                                                                                                                                                                                                                       

ERROR: Chef failed to converge: directory[C:/Users/user01/Desktop/thisiscool] (code_generator::cookbook line 6) had an error: Chef::Exceptions::InsufficientPermissions: Cannot create directory[C:/Users/user01/Desktop/thisiscool] at C:
/Users/user01/Desktop/thisiscool due to insufficient permissions                                                                                                                                                                      

However, if I open command prompt in the desired directory, and don't cd to a different one, then it works just fine.

@danielsdeleo
Copy link
Contributor

@chef/client-windows Any ideas?

@smurawski
Copy link

@danielsdeleo I can replicate this with ChefDK 0.4.0. I'll try to dig deeper tonight.

@danielsdeleo
Copy link
Contributor

@smurawski Thank you!

@smurawski
Copy link

This doesn't appear to be chefdk specific nor tied to the cd command. To replicate I was able to

#Worked 
chef-apply --% -e 'directory "c:/users/administrator/test"'
#Failed
chef-apply --% -e 'directory "c:/users/administrator/desktop/test'
#Worked
chef-apply --% -e 'directory "c:/test'
#Failed
chef-apply --% -e 'directory "c:/users/test'

@danielsdeleo @predatorian3
I've opened an issue in the Chef repo ( chef/chef#3164 ) and will continue investigating there.

@smurawski smurawski self-assigned this Mar 28, 2015
@smurawski
Copy link

Looks like this bug was fixed in chef-client 12.1.0 via chef/chef#2896

The bug goes back into the 11.x line of chef-client as well. It only seems to impact certain locations (mainly related to the Administrator account). My expectation is that ChefDK 0.5.0 will be the fix for this issue.

@smurawski
Copy link

Resolved with ChefDK 0.5.0 or newer.

@thommay thommay added Type: Bug Doesn't work as expected. and removed Bug labels Feb 1, 2017
@chef-boneyard chef-boneyard locked and limited conversation to collaborators Feb 14, 2018
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
Platform: Windows Type: Bug Doesn't work as expected.
Development

No branches or pull requests

5 participants