fixed: win_copy: typo "file file" (double "file") (#33620)

* fixed: win_copy: typo "file file" (double "file")

Signed-off-by: Alexey Shumkin <Alex.Crezoff@gmail.com>

* Add quotes around filenames/directories

* Fix tests for new quotes

* Fix tests for new quotes

* One more ?

* Another one...
This commit is contained in:
Alexey Shumkin 2017-12-07 02:42:39 +03:00 committed by Dag Wieers
parent 4071cd7a95
commit 6f719ea848
3 changed files with 23 additions and 23 deletions

View file

@ -1,8 +1,8 @@
#!powershell #!powershell
# This file is part of Ansible # This file is part of Ansible
# (c) 2015, Jon Hawkesworth (@jhawkesworth) <figs@unity.demon.co.uk> # Copyright: (c) 2015, Jon Hawkesworth (@jhawkesworth) <figs@unity.demon.co.uk>
# Copyright (c) 2017 Ansible Project # Copyright: (c) 2017, Ansible Project
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
#Requires -Module Ansible.ModuleUtils.Legacy #Requires -Module Ansible.ModuleUtils.Legacy
@ -52,7 +52,7 @@ Function Copy-File($source, $dest) {
} }
if (Test-Path -Path $dest -PathType Container) { if (Test-Path -Path $dest -PathType Container) {
Fail-Json -obj $result -message "cannot copy file from $source to $($dest): dest is already a folder" Fail-Json -obj $result -message "cannot copy file from '$source' to '$dest': dest is already a folder"
} elseif (Test-Path -Path $dest -PathType Leaf) { } elseif (Test-Path -Path $dest -PathType Leaf) {
if ($force) { if ($force) {
$target_checksum = Get-FileChecksum -path $dest $target_checksum = Get-FileChecksum -path $dest
@ -68,7 +68,7 @@ Function Copy-File($source, $dest) {
$file_dir = [System.IO.Path]::GetDirectoryName($dest) $file_dir = [System.IO.Path]::GetDirectoryName($dest)
# validate the parent dir is not a file and that it exists # validate the parent dir is not a file and that it exists
if (Test-Path -Path $file_dir -PathType Leaf) { if (Test-Path -Path $file_dir -PathType Leaf) {
Fail-Json -obj $result -message "cannot copy file from $source to $($dest): object at dest parent dir is not a folder" Fail-Json -obj $result -message "cannot copy file from '$source' to '$dest': object at dest parent dir is not a folder"
} elseif (-not (Test-Path -Path $file_dir)) { } elseif (-not (Test-Path -Path $file_dir)) {
# directory doesn't exist, need to create # directory doesn't exist, need to create
New-Item -Path $file_dir -ItemType Directory -WhatIf:$check_mode | Out-Null New-Item -Path $file_dir -ItemType Directory -WhatIf:$check_mode | Out-Null
@ -102,10 +102,10 @@ Function Copy-Folder($source, $dest) {
if (-not (Test-Path -Path $dest -PathType Container)) { if (-not (Test-Path -Path $dest -PathType Container)) {
$parent_dir = [System.IO.Path]::GetDirectoryName($dest) $parent_dir = [System.IO.Path]::GetDirectoryName($dest)
if (Test-Path -Path $parent_dir -PathType Leaf) { if (Test-Path -Path $parent_dir -PathType Leaf) {
Fail-Json -obj $result -message "cannot copy file from $source to $($dest): object at dest parent dir is not a folder" Fail-Json -obj $result -message "cannot copy file from '$source' to '$dest': object at dest parent dir is not a folder"
} }
if (Test-Path -Path $dest -PathType Leaf) { if (Test-Path -Path $dest -PathType Leaf) {
Fail-Json -obj $result -message "cannot copy folder from $source to $($dest): dest is already a file" Fail-Json -obj $result -message "cannot copy folder from '$source' to '$dest': dest is already a file"
} }
New-Item -Path $dest -ItemType Container -WhatIf:$check_mode | Out-Null New-Item -Path $dest -ItemType Container -WhatIf:$check_mode | Out-Null
@ -158,10 +158,10 @@ Function Extract-Zip($src, $dest) {
if ($archive_name.EndsWith("/") -or $archive_name.EndsWith("`\")) { if ($archive_name.EndsWith("/") -or $archive_name.EndsWith("`\")) {
$base64_name = $archive_name.Substring(0, $archive_name.Length - 1) $base64_name = $archive_name.Substring(0, $archive_name.Length - 1)
} else { } else {
throw "invalid base64 archive name $archive_name" throw "invalid base64 archive name '$archive_name'"
} }
} else { } else {
throw "invalid base64 length $archive_name" throw "invalid base64 length '$archive_name'"
} }
# to handle unicode character, win_copy action plugin has encoded the filename # to handle unicode character, win_copy action plugin has encoded the filename
@ -245,7 +245,7 @@ if ($mode -eq "query") {
} }
} }
} elseif (Test-Path -Path $filepath -PathType Container) { } elseif (Test-Path -Path $filepath -PathType Container) {
Fail-Json -obj $result -message "cannot copy file to dest $($filepath): object at path is already a directory" Fail-Json -obj $result -message "cannot copy file to dest '$filepath': object at path is already a directory"
} else { } else {
$changed_files += $file $changed_files += $file
} }
@ -257,10 +257,10 @@ if ($mode -eq "query") {
$dirpath = Join-Path -Path $dest -ChildPath $dirname $dirpath = Join-Path -Path $dest -ChildPath $dirname
$parent_dir = [System.IO.Path]::GetDirectoryName($dirpath) $parent_dir = [System.IO.Path]::GetDirectoryName($dirpath)
if (Test-Path -Path $parent_dir -PathType Leaf) { if (Test-Path -Path $parent_dir -PathType Leaf) {
Fail-Json -obj $result -message "cannot copy folder to dest $($dirpath): object at parent directory path is already a file" Fail-Json -obj $result -message "cannot copy folder to dest '$dirpath': object at parent directory path is already a file"
} }
if (Test-Path -Path $dirpath -PathType Leaf) { if (Test-Path -Path $dirpath -PathType Leaf) {
Fail-Json -obj $result -message "cannot copy folder to dest $($dirpath): object at path is already a file" Fail-Json -obj $result -message "cannot copy folder to dest '$dirpath': object at path is already a file"
} elseif (-not (Test-Path -Path $dirpath -PathType Container)) { } elseif (-not (Test-Path -Path $dirpath -PathType Container)) {
$changed_directories += $directory $changed_directories += $directory
} }
@ -276,7 +276,7 @@ if ($mode -eq "query") {
# expanded this will always result in a change as the calculation is done # expanded this will always result in a change as the calculation is done
# on the win_copy action plugin and is only run if a change needs to occur # on the win_copy action plugin and is only run if a change needs to occur
if (-not (Test-Path -Path $src -PathType Leaf)) { if (-not (Test-Path -Path $src -PathType Leaf)) {
Fail-Json -obj $result -message "Cannot expand src zip file file: $src as it does not exist" Fail-Json -obj $result -message "Cannot expand src zip file: '$src' as it does not exist"
} }
# Detect if the PS zip assemblies are available or whether to use Shell # Detect if the PS zip assemblies are available or whether to use Shell
@ -301,7 +301,7 @@ if ($mode -eq "query") {
$result.dest = $dest $result.dest = $dest
if (-not (Test-Path -Path $src)) { if (-not (Test-Path -Path $src)) {
Fail-Json -obj $result -message "Cannot copy src file: $src as it does not exist" Fail-Json -obj $result -message "Cannot copy src file: '$src' as it does not exist"
} }
if (Test-Path -Path $src -PathType Container) { if (Test-Path -Path $src -PathType Container) {
@ -340,9 +340,9 @@ if ($mode -eq "query") {
# file and dest if the path to a file (doesn't end with \ or /) # file and dest if the path to a file (doesn't end with \ or /)
$parent_dir = Split-Path -Path $dest $parent_dir = Split-Path -Path $dest
if (Test-Path -Path $parent_dir -PathType Leaf) { if (Test-Path -Path $parent_dir -PathType Leaf) {
Fail-Json -obj $result -message "object at destination parent dir $parent_dir is currently a file" Fail-Json -obj $result -message "object at destination parent dir '$parent_dir' is currently a file"
} elseif (-not (Test-Path -Path $parent_dir -PathType Container)) { } elseif (-not (Test-Path -Path $parent_dir -PathType Container)) {
Fail-Json -obj $result -message "Destination directory $parent_dir does not exist" Fail-Json -obj $result -message "Destination directory '$parent_dir' does not exist"
} }
} }
$copy_result = Copy-File -source $src -dest $dest $copy_result = Copy-File -source $src -dest $dest
@ -364,7 +364,7 @@ if ($mode -eq "query") {
# always result in a change as the calculation is done on the Ansible side # always result in a change as the calculation is done on the Ansible side
# before this is run. This should also never run in check mode # before this is run. This should also never run in check mode
if (-not (Test-Path -Path $src -PathType Leaf)) { if (-not (Test-Path -Path $src -PathType Leaf)) {
Fail-Json -obj $result -message "Cannot copy src file: $src as it does not exist" Fail-Json -obj $result -message "Cannot copy src file: '$src' as it does not exist"
} }
# the dest parameter is a directory, we need to append original_basename # the dest parameter is a directory, we need to append original_basename
@ -374,7 +374,7 @@ if ($mode -eq "query") {
# when dest ends with /, we need to create the destination directories # when dest ends with /, we need to create the destination directories
if (Test-Path -Path $parent_dir -PathType Leaf) { if (Test-Path -Path $parent_dir -PathType Leaf) {
Fail-Json -obj $result -message "object at destination parent dir $parent_dir is currently a file" Fail-Json -obj $result -message "object at destination parent dir '$parent_dir' is currently a file"
} elseif (-not (Test-Path -Path $parent_dir -PathType Container)) { } elseif (-not (Test-Path -Path $parent_dir -PathType Container)) {
New-Item -Path $parent_dir -ItemType Directory | Out-Null New-Item -Path $parent_dir -ItemType Directory | Out-Null
} }
@ -384,9 +384,9 @@ if ($mode -eq "query") {
# check if the dest parent dirs exist, need to fail if they don't # check if the dest parent dirs exist, need to fail if they don't
if (Test-Path -Path $parent_dir -PathType Leaf) { if (Test-Path -Path $parent_dir -PathType Leaf) {
Fail-Json -obj $result -message "object at destination parent dir $parent_dir is currently a file" Fail-Json -obj $result -message "object at destination parent dir '$parent_dir' is currently a file"
} elseif (-not (Test-Path -Path $parent_dir -PathType Container)) { } elseif (-not (Test-Path -Path $parent_dir -PathType Container)) {
Fail-Json -obj $result -message "Destination directory $parent_dir does not exist" Fail-Json -obj $result -message "Destination directory '$parent_dir' does not exist"
} }
} }

View file

@ -5,7 +5,7 @@
dest: fakedest dest: fakedest
remote_src: yes remote_src: yes
register: fail_remote_invalid_source register: fail_remote_invalid_source
failed_when: "fail_remote_invalid_source.msg != 'Cannot copy src file: fakesource as it does not exist'" failed_when: "'it does not exist' not in fail_remote_invalid_source.msg"
- name: setup source folder for remote tests - name: setup source folder for remote tests
win_copy: win_copy:
@ -43,7 +43,7 @@
dest: '{{test_win_copy_path}}\target\file\foo.txt' dest: '{{test_win_copy_path}}\target\file\foo.txt'
remote_src: yes remote_src: yes
register: fail_remote_file_parent_dir_file register: fail_remote_file_parent_dir_file
failed_when: fail_remote_file_parent_dir_file.msg != 'object at destination parent dir ' + test_win_copy_path + '\\target\\file is currently a file' failed_when: "'is currently a file' not in fail_remote_file_parent_dir_file.msg"
- name: fail source is a folder dest parent dir is also a file - name: fail source is a folder dest parent dir is also a file
win_copy: win_copy:
@ -59,7 +59,7 @@
dest: '{{test_win_copy_path}}\missing-dir\foo.txt' dest: '{{test_win_copy_path}}\missing-dir\foo.txt'
remote_src: yes remote_src: yes
register: fail_remote_missing_parent_dir register: fail_remote_missing_parent_dir
failed_when: "'Destination directory ' + test_win_copy_path + '\\missing-dir does not exist' not in fail_remote_missing_parent_dir.msg" failed_when: "'does not exist' not in fail_remote_missing_parent_dir.msg"
- name: remove target after remote failure tests - name: remove target after remote failure tests
win_file: win_file:

View file

@ -24,7 +24,7 @@
src: foo.txt src: foo.txt
dest: '{{test_win_copy_path}}\missing-dir\foo.txt' dest: '{{test_win_copy_path}}\missing-dir\foo.txt'
register: fail_missing_parent_dir register: fail_missing_parent_dir
failed_when: "'Destination directory ' + test_win_copy_path + '\\missing-dir does not exist' not in fail_missing_parent_dir.msg" failed_when: "'does not exist' not in fail_missing_parent_dir.msg"
- name: fail to copy an encrypted file without the password set - name: fail to copy an encrypted file without the password set
win_copy: win_copy: