File: 60-assert-11-assert_file_no_permissions.bats

package info (click to toggle)
bats-file 0.3.0%2Bgit20230131-gbba751f-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 408 kB
  • sloc: sh: 566; makefile: 2
file content (74 lines) | stat: -rw-r--r-- 2,755 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#!/usr/bin/env bats

load 'test_helper'
fixtures 'exist'

setup () {
  touch ${TEST_FIXTURE_ROOT}/dir/permission ${TEST_FIXTURE_ROOT}/dir/nopermission
  chmod 777 ${TEST_FIXTURE_ROOT}/dir/permission
  chmod 644 ${TEST_FIXTURE_ROOT}/dir/nopermission
}
teardown () {
  rm -f ${TEST_FIXTURE_ROOT}/dir/permission ${TEST_FIXTURE_ROOT}/dir/nopermission
}

# Correctness
@test 'assert_not_file_permission() <file>: returns 0 if <file> file does not have permissions 777' {
  local -r permission="777"
  local -r file="${TEST_FIXTURE_ROOT}/dir/nopermission"
  run assert_not_file_permission "$permission" "$file"
  [ "$status" -eq 0 ]
  [ "${#lines[@]}" -eq 0 ]
}

@test 'assert_not_file_permission() <file>: returns 1 and displays path if <file> file has permissions 777, but it was expected not to have' {
  local -r permission="777"
  local -r file="${TEST_FIXTURE_ROOT}/dir/permission"
  run assert_not_file_permission "$permission" "$file"
  [ "$status" -eq 1 ]
  [ "${#lines[@]}" -eq 3 ]
  [ "${lines[0]}" == '-- file has permissions 777, but it was expected not to have --' ]
  [ "${lines[1]}" == "path : $file" ]
  [ "${lines[2]}" == '--' ]
}


# Transforming path
@test 'assert_not_file_permission() <file>: replace prefix of displayed path' {
  local -r BATSLIB_FILE_PATH_REM="#${TEST_FIXTURE_ROOT}"
  local -r BATSLIB_FILE_PATH_ADD='..'
  local -r permission="777"
  local -r file="${TEST_FIXTURE_ROOT}/dir/permission"
  run assert_not_file_permission "$permission" "$file"
  [ "$status" -eq 1 ]
  [ "${#lines[@]}" -eq 3 ]
  [ "${lines[0]}" == '-- file has permissions 777, but it was expected not to have --' ]
  [ "${lines[1]}" == "path : ../dir/permission" ]
  [ "${lines[2]}" == '--' ]
}

@test 'assert_not_file_permission() <file>: replace suffix of displayed path' {
  local -r BATSLIB_FILE_PATH_REM='%dir/permission'
  local -r BATSLIB_FILE_PATH_ADD='..'
  local -r permission="777"
  local -r file="${TEST_FIXTURE_ROOT}/dir/permission"
  run assert_not_file_permission "$permission" "$file"
  [ "$status" -eq 1 ]
  [ "${#lines[@]}" -eq 3 ]
  [ "${lines[0]}" == '-- file has permissions 777, but it was expected not to have --' ]
  [ "${lines[1]}" == "path : ${TEST_FIXTURE_ROOT}/.." ]
  [ "${lines[2]}" == '--' ]
}

@test 'assert_not_file_permission() <file>: replace infix of displayed path' {
  local -r BATSLIB_FILE_PATH_REM='dir/permission'
  local -r BATSLIB_FILE_PATH_ADD='..'
  local -r permission="777"
  local -r file="${TEST_FIXTURE_ROOT}/dir/permission"
  run assert_not_file_permission "$permission" "$file"
  [ "$status" -eq 1 ]
  [ "${#lines[@]}" -eq 3 ]
  [ "${lines[0]}" == '-- file has permissions 777, but it was expected not to have --' ]
  [ "${lines[1]}" == "path : ${TEST_FIXTURE_ROOT}/.." ]
  [ "${lines[2]}" == '--' ]
}