-
Notifications
You must be signed in to change notification settings - Fork 188
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added acceptance test for testing that files converted to directories should be changed back to files on recusive copy. The test is currently set to soft fail. Ticket: CFE-2216 Changelog: None Signed-off-by: Lars Erik Wik <[email protected]>
- Loading branch information
Showing
2 changed files
with
140 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,111 @@ | ||
############################################################ | ||
# CFE-2216: Files converted to directories should be changed | ||
# back on recursive copy | ||
############################################################ | ||
|
||
body common control | ||
{ | ||
bundlesequence => { "init", "test", "check", "clean" }; | ||
version => "1.0"; | ||
} | ||
|
||
bundle common G { | ||
vars: | ||
"testdir" | ||
string => concat( | ||
getenv("TEMP", "65535"), | ||
"$(const.dirsep)TESTDIR.cfengine" | ||
); | ||
} | ||
|
||
body delete tidy | ||
{ | ||
dirlinks => "delete"; | ||
rmdirs => "true"; | ||
} | ||
|
||
body contain use_shell | ||
{ | ||
useshell => "useshell"; | ||
} | ||
|
||
############################################################ | ||
|
||
bundle agent init | ||
{ | ||
files: | ||
"$(G.testdir)/src/." | ||
create => "true"; | ||
"$(G.testdir)/src/foo" | ||
content => "Hello CFEngine!"; | ||
"$(G.testdir)/src/bar/." | ||
create => "true"; | ||
|
||
# The .sub file needs to know the value of $(G.testdir). We can use a | ||
# template in order to hardcode it in before execution. | ||
"$(this.promise_filename).sub" | ||
create => "true", | ||
edit_template => "$(this.promise_filename).template", | ||
template_method => "mustache", | ||
template_data => parsejson('{ "testdir": "$(G.testdir)" }'); | ||
} | ||
|
||
############################################################ | ||
|
||
bundle agent test | ||
{ | ||
meta: | ||
"description" -> { "CFE-2216" } | ||
string => "Files converted to directories should be changed back on recursive copy"; | ||
|
||
# This bug is not yet fixed, so we need to soft fail it | ||
"test_soft_fail" | ||
string => "any", | ||
meta => { "CFE-2216" }; | ||
|
||
commands: | ||
# Sync files between source and destination dir | ||
"$(sys.cf_agent) -Kf $(this.promise_filename).sub"; | ||
|
||
# Change foo from a file to a directory | ||
"rm $(G.testdir)/dst/foo && mkdir $(G.testdir)/dst/foo" | ||
contain => use_shell; | ||
|
||
# Change bar from a directory to a file | ||
"rmdir $(G.testdir)/dst/bar && touch $(G.testdir)/dst/bar" | ||
contain => use_shell; | ||
|
||
# Sync the files again. We append -- at the end to make sure the promise | ||
# hash is different | ||
"$(sys.cf_agent) -Kf $(this.promise_filename).sub --"; | ||
} | ||
|
||
############################################################ | ||
|
||
bundle agent check | ||
{ | ||
classes: | ||
# Check that foo is converted back to a file and that bar is converted | ||
# back to a directory | ||
"ok" | ||
expression => and( | ||
not(isdir("$(G.testdir)/dst/foo")), | ||
isdir("$(G.testdir)/dst/bar") | ||
); | ||
|
||
reports: | ||
ok:: | ||
"$(this.promise_filename) Pass"; | ||
!ok:: | ||
"$(this.promise_filename) FAIL"; | ||
} | ||
|
||
bundle agent clean | ||
{ | ||
# Clean up the files generated from the template | ||
files: | ||
"$(this.promise_filename).sub" | ||
delete => tidy; | ||
"$(this.promise_filename).sub.cf-before-edit" | ||
delete => tidy; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
############################################################ | ||
# CFE-2216: Files converted to directories should be changed | ||
# back on recursive copy | ||
############################################################ | ||
|
||
bundle common G { | ||
vars: | ||
"testdir" | ||
string => "{{testdir}}"; | ||
} | ||
|
||
body depth_search recurse { | ||
depth => "inf"; | ||
xdev => "true"; | ||
} | ||
|
||
body copy_from source_dir { | ||
source => "$(G.testdir)/src"; | ||
compare => "digest"; | ||
} | ||
|
||
bundle agent main | ||
{ | ||
files: | ||
"$(G.testdir)/dst" | ||
copy_from => source_dir, | ||
move_obstructions => "true", | ||
depth_search => recurse; | ||
} |