Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Test the RUNTIME_IGNOREDOTFILES environment variable #78

Merged
merged 16 commits into from
Oct 30, 2019
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ Fencer-specific environment variables are:
- `RUNTIME_IGNOREDOTFILES` - A flag indicating whether to ignore files
with names starting with a dot (hidden files on Linux-based systems
and macOS). It can be `True` or `False`. The default value is
`False`.
`False`. Directories with names starting in a dot are not ignored.
mdimjasevic marked this conversation as resolved.
Show resolved Hide resolved
- `GRPC_PORT` - The port to run the gRPC server on. Default is 8081.

## Developing
Expand Down
50 changes: 44 additions & 6 deletions test/Fencer/Rules/Test.hs
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import Test.Tasty (TestTree, testGroup)
import Test.Tasty.HUnit (assertEqual, testCase)

import Fencer.Rules
import Fencer.Settings (getSettingsFromEnvironment, settingsIgnoreDotFiles)
import Fencer.Types


Expand All @@ -26,20 +27,58 @@ tests = testGroup "Rule tests"
[ test_rulesLoadRulesYaml
, test_rulesLoadRulesNonYaml
, test_rulesLoadRulesRecursively
, test_rulesLoadRulesDotDirectory
, test_rulesLoadRulesRUNTIME_IGNOREDOTFILES
]

-- | A helper function for loading rules and making sure they are as
-- expected.
loadRules :: String -> Bool -> IO ()
loadRules dirTemplate ignoreDotFiles =
Temp.withSystemTempDirectory dirTemplate $ \tempDir -> do
TIO.writeFile (tempDir </> "config1.yml") domain1Text
TIO.writeFile (tempDir </> "config2.yaml") domain2Text
definitions <-
loadRulesFromDirectory
(#directory tempDir)
(#ignoreDotFiles ignoreDotFiles)
assertEqual "unexpected definitions"
(sortOn domainDefinitionId [domain1, domain2])
(sortOn domainDefinitionId definitions)


-- | test that 'loadRulesFromDirectory' loads rules from YAML files.
test_rulesLoadRulesYaml :: TestTree
test_rulesLoadRulesYaml =
testCase "Rules are loaded from YAML files" $
loadRules "fencer-config" True

-- | test that 'loadRulesFromDirectory' loads rules from a
-- dot-directory when dot-files should be ignored.
test_rulesLoadRulesDotDirectory :: TestTree
test_rulesLoadRulesDotDirectory =
testCase "Rules are loaded from a dot-directory" $
loadRules ".fencer-config" True


-- | test that 'loadRulesFromDirectory' respects the
mdimjasevic marked this conversation as resolved.
Show resolved Hide resolved
-- RUNTIME_IGNOREDOTFILES environment variable.
test_rulesLoadRulesRUNTIME_IGNOREDOTFILES :: TestTree
test_rulesLoadRulesRUNTIME_IGNOREDOTFILES =
mdimjasevic marked this conversation as resolved.
Show resolved Hide resolved
testCase "Rules are not loaded from a dot-file" $ do
setEnv "RUNTIME_IGNOREDOTFILES" "true"
setEnv "RUNTIME_SUBDIRECTORY" "sub" -- this value will not be used anyway
settings <- getSettingsFromEnvironment
Temp.withSystemTempDirectory "fencer-config" $ \tempDir -> do
TIO.writeFile (tempDir </> "config1.yml") domain1Text
TIO.writeFile (tempDir </> "config2.yaml") domain2Text
TIO.writeFile (tempDir </> ".config2.yaml") domain2Text
definitions <-
loadRulesFromDirectory (#directory tempDir) (#ignoreDotFiles True)
assertEqual "unexpected definitions"
(sortOn domainDefinitionId [domain1, domain2])
(sortOn domainDefinitionId definitions)
loadRulesFromDirectory
(#directory tempDir)
(#ignoreDotFiles $ settingsIgnoreDotFiles settings)
assertEqual "RUNTIME_IGNOREDOTFILES not respected!"
[domain1]
definitions

-- | Test that 'loadRulesFromDirectory' loads rules from all files, not just
-- YAML files.
Expand Down Expand Up @@ -74,7 +113,6 @@ test_rulesLoadRulesRecursively =
(sortOn domainDefinitionId [domain1, domain2])
(sortOn domainDefinitionId definitions)


----------------------------------------------------------------------------
-- Sample definitions
----------------------------------------------------------------------------
Expand Down