fleet/orbit/pkg/table/dscl/dscl_darwin_test.go
Lucas Manuel Rodriguez 4638e8564f
Add check for CIS 5.6 (#9756)
#9260

- [X] Changes file added for user-visible changes in `changes/` or
`orbit/changes/`.
See [Changes
files](https://fleetdm.com/docs/contributing/committing-changes#changes-files)
for more information.
- ~[ ] Documented any API changes (docs/Using-Fleet/REST-API.md or
docs/Contributing/API-for-contributors.md)~
- ~[ ] Documented any permissions changes~
- ~[ ] Input data is properly validated, `SELECT *` is avoided, SQL
injection is prevented (using placeholders for values in statements)~
- ~[ ] Added support on fleet's osquery simulator `cmd/osquery-perf` for
new osquery data ingestion features.~
- [X] Added/updated tests
- [X] Manual QA for all new/changed functionality
  - For Orbit and Fleet Desktop changes:
- [X] Manual QA must be performed in the three main OSs, macOS, Windows
and Linux.
- ~[ ] Auto-update manual QA, from released version of component to new
version (see [tools/tuf/test](../tools/tuf/test/README.md)).~
2023-02-09 14:27:40 -03:00

97 lines
3.1 KiB
Go

//go:build darwin
// +build darwin
package dscl
import (
"testing"
"github.com/stretchr/testify/require"
)
func TestParseDSCLOutput(t *testing.T) {
// NOTE(lucas): I've seen the following behavior when running the command as non-root.
const noKeySample = `No such key: Foobar`
value, err := parseDSCLReadOutput([]byte(noKeySample))
require.NoError(t, err)
require.Nil(t, value)
// NOTE(lucas): I've seen the following behavior when running the command as root.
const noKeySample2 = ``
value, err = parseDSCLReadOutput([]byte(noKeySample2))
require.NoError(t, err)
require.Nil(t, value)
const keySample0 = `PrimaryGroupID: 20`
value, err = parseDSCLReadOutput([]byte(keySample0))
require.NoError(t, err)
require.NotNil(t, value)
require.Equal(t, "20", *value)
const keySample1 = `Picture:
/Library/User Pictures/Animals/Penguin.tif`
value, err = parseDSCLReadOutput([]byte(keySample1))
require.NoError(t, err)
require.NotNil(t, value)
require.Equal(t, "/Library/User Pictures/Animals/Penguin.tif", *value)
const keySample2 = `RecordName: foo com.apple.idms.appleid.prd.0A771AC1-B614-4A18-9FA5-0ADFA8EED4BC`
value, err = parseDSCLReadOutput([]byte(keySample2))
require.NoError(t, err)
require.NotNil(t, value)
require.Equal(t, "foo com.apple.idms.appleid.prd.0A771AC1-B614-4A18-9FA5-0ADFA8EED4BC", *value)
const keySample3 = `dsAttrTypeNative:accountPolicyData:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>creationTime</key>
<real>1634811726.5620289</real>
<key>failedLoginCount</key>
<integer>0</integer>
<key>failedLoginTimestamp</key>
<integer>0</integer>
<key>passwordLastSetTime</key>
<real>1636975330.6275649</real>
</dict>
</plist>`
value, err = parseDSCLReadOutput([]byte(keySample3))
require.NoError(t, err)
require.NotNil(t, value)
require.Equal(t, `<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>creationTime</key>
<real>1634811726.5620289</real>
<key>failedLoginCount</key>
<integer>0</integer>
<key>failedLoginTimestamp</key>
<integer>0</integer>
<key>passwordLastSetTime</key>
<real>1636975330.6275649</real>
</dict>
</plist>`, *value)
const keySample4 = `RecordType: dsRecTypeStandard:Users`
value, err = parseDSCLReadOutput([]byte(keySample4))
require.NoError(t, err)
require.NotNil(t, value)
require.Equal(t, "dsRecTypeStandard:Users", *value)
const keySample5 = `RecordName:
root
BUILTIN\Local System`
value, err = parseDSCLReadOutput([]byte(keySample5))
require.NoError(t, err)
require.NotNil(t, value)
require.Equal(t, `root
BUILTIN\Local System`, *value)
const keySample6 = `NFSHomeDirectory: /var/root /private/var/root`
value, err = parseDSCLReadOutput([]byte(keySample6))
require.NoError(t, err)
require.NotNil(t, value)
require.Equal(t, `/var/root /private/var/root`, *value)
}