Merge pull request #10156 from chrisroberts/f-smb-list-parse

Extract smblist information based on position
This commit is contained in:
Chris Roberts 2018-08-30 11:32:45 -07:00 committed by GitHub
commit a5177f506d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 28 additions and 7 deletions

View File

@ -138,15 +138,10 @@ module VagrantPlugins
name = nil name = nil
until share_data.empty? until share_data.empty?
content = share_data.take_while{|line| !line.strip.empty? } content = share_data.take_while{|line| !line.strip.empty? }
if content.size != 3
@@logger.warn("expected SMB data check to be size 3 but was size #{content.size}")
@@logger.debug("unprocessed SMB data: #{content.inspect}")
next
end
share_name = content[0].strip.split(":", 2).last.strip share_name = content[0].strip.split(":", 2).last.strip
shares[share_name] = { shares[share_name] = {
"Path" => content[1].strip.split(":", 2).last.strip, "Path" => content[-2].strip.split(":", 2).last.strip,
"Description" => content[2].strip.split(":", 2).last.strip "Description" => content[-1].strip.split(":", 2).last.strip
} }
share_data.slice!(0, content.length + 1) share_data.slice!(0, content.length + 1)
end end

View File

@ -22,6 +22,10 @@ Name : my-share
Path : /my/path Path : /my/path
Description : Not Vagrant Owned Description : Not Vagrant Owned
Name : scoped-share
Scope : *
Path : /scoped/path
Description : Scoped Path
EOF EOF
} }
let(:netsharelist){ <<-EOF let(:netsharelist){ <<-EOF
@ -225,4 +229,26 @@ Remark Not Vagrant Owned
end end
end end
end end
describe ".get_smbshares" do
before { expect(Vagrant::Util::PowerShell).to receive(:execute_cmd).and_return(smblist) }
it "should return a Hash of share information" do
expect(subject.get_smbshares).to be_a(Hash)
end
it "should provide name and description for share" do
shares = subject.get_smbshares
expect(shares["vgt-CUSTOM_ID-1"]).to be_a(Hash)
expect(shares["vgt-CUSTOM_ID-1"]["Path"]).to eq("/a/path")
expect(shares["vgt-CUSTOM_ID-1"]["Description"]).to eq("vgt-CUSTOM_ID-1")
end
it "should properly handle share with scope information" do
shares = subject.get_smbshares
expect(shares["scoped-share"]).to be_a(Hash)
expect(shares["scoped-share"]["Path"]).to eq("/scoped/path")
expect(shares["scoped-share"]["Description"]).to eq("Scoped Path")
end
end
end end