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

fix: adding Sanitize() method to Data interface #168

Closed
wants to merge 45 commits into from
Closed
Changes from 9 commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
95170b0
fix: handling nil value for `compare` method of decData
0xankit Dec 8, 2022
19574b3
Merge branch 'master' into 0xankit/decDatafixes
deepanshutr Dec 9, 2022
764911a
fix: add `sanitize` method to `Data` interface
0xankit Dec 9, 2022
8ac65d1
Merge branch '0xankit/decDatafixes' of github.com:AssetMantle/modules…
0xankit Dec 9, 2022
51f8a47
test: update test for GetID method
0xankit Dec 9, 2022
30aac7c
test(schema): add `sanitize` method for accAddressData
0xankit Dec 9, 2022
9338cd3
test(schema): add `sanitize` method for booleanData
0xankit Dec 9, 2022
9dac67c
test(schema): add `sanitize` method for heightData
0xankit Dec 9, 2022
9ec054d
test(schema): add `sanitize` method for idData
0xankit Dec 9, 2022
79299ce
test(schema): add `sanitize` method for listData
0xankit Dec 12, 2022
7a2be4b
test(schema): add `sanitize` method for stringData
0xankit Dec 12, 2022
d28cd94
closes #123
0xankit Dec 12, 2022
2576b11
test(schema): update tests for propertylist
0xankit Dec 13, 2022
7b266b5
tests(schema): closes #30
0xankit Dec 13, 2022
b5012c0
Merge branch 'master' of github.com:AssetMantle/modules into 0xankit/…
0xankit Dec 13, 2022
79a69e5
fix: resolving merge conflicts
0xankit Dec 13, 2022
feb7915
test(schema): update test for accAddressData compare method
0xankit Dec 13, 2022
1239590
Merge branch 'master' of github.com:AssetMantle/modules into 0xankit/…
0xankit Dec 14, 2022
e0d80a7
test: mock fix
0xankit Dec 14, 2022
7fe7c7c
test: closes #165
0xankit Dec 14, 2022
9d3e003
test(schema): update tests for propertyList
0xankit Dec 14, 2022
3eb6751
test(schema): add test for nil case in idList
0xankit Dec 14, 2022
f2b4a84
test(schema): add test for maintainers
0xankit Dec 14, 2022
12787d6
code refactoring
0xankit Dec 14, 2022
5e3a5d5
test(schema): add tests for order Documents
0xankit Dec 14, 2022
7a84786
code refactoring
0xankit Dec 14, 2022
33fecbd
fix(schema): add sanitize method for documents
0xankit Dec 15, 2022
8fad47f
test(schema): add tests for ids utilities
0xankit Dec 15, 2022
85797a4
fix(schema): add sanitize method for dataList
0xankit Dec 15, 2022
756cc1e
fix(schema): add sanitize method for idList
0xankit Dec 15, 2022
3045e99
fix(schema): add sanitize method for propertyList
0xankit Dec 16, 2022
747f4df
fix: add sanitize method for lists
0xankit Dec 16, 2022
cbd3307
tests(schema): add tests for storeKeyPrefix
0xankit Dec 16, 2022
ce0cf08
test(schema): add tests for splitIDs ID
0xankit Dec 16, 2022
aac9b1d
test(schema): add tests for ownableID
0xankit Dec 16, 2022
e4833a5
test(schema): add tests for assetID
0xankit Dec 19, 2022
97593be
test(schema): add tests for classification IDs
0xankit Dec 19, 2022
cffbfa6
test(schema): add tests for identityIDs
0xankit Dec 19, 2022
63a607b
test(schema): add tests for maintainerID
0xankit Dec 20, 2022
0a5fb29
test(schema): add tests for orderID
0xankit Dec 20, 2022
5709958
code refactoring
0xankit Dec 21, 2022
a4eddc7
Merge pull request #181 from AssetMantle/0xankit/schemaTests
0xankit Dec 21, 2022
3004412
Merge branch '0xankit/ReadDataStringSanitize' of github.com:AssetMant…
0xankit Dec 21, 2022
37f268f
Merge branch '0xankit/decDatafixes' of github.com:AssetMantle/modules…
0xankit Dec 21, 2022
342dc34
Merge branch '0xankit/sanitizeData' of github.com:AssetMantle/modules…
0xankit Dec 21, 2022
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
10 changes: 6 additions & 4 deletions schema/documents/base/classification_test.go
Original file line number Diff line number Diff line change
@@ -13,11 +13,13 @@ import (
baseQualified "github.com/AssetMantle/modules/schema/qualified/base"
)

func Test_new_Classification(t *testing.T) {
immutables := baseQualified.NewImmutables(baseLists.NewPropertyList(baseProperties.NewMesaProperty(baseIDs.NewStringID("ID1"), baseData.NewStringData("ImmutableData"))))
mutables := baseQualified.NewMutables(baseLists.NewPropertyList(baseProperties.NewMesaProperty(baseIDs.NewStringID("ID2"), baseData.NewStringData("MutableData"))))
var (
immutables = baseQualified.NewImmutables(baseLists.NewPropertyList(baseProperties.NewMesaProperty(baseIDs.NewStringID("ID1"), baseData.NewStringData("ImmutableData"))))
mutables = baseQualified.NewMutables(baseLists.NewPropertyList(baseProperties.NewMesaProperty(baseIDs.NewStringID("ID2"), baseData.NewStringData("MutableData"))))
testClassification = NewClassification(immutables, mutables)
)

testClassification := NewClassification(immutables, mutables)
func Test_new_Classification(t *testing.T) {
type fields struct {
immutables qualified.Immutables
mutables qualified.Mutables
363 changes: 363 additions & 0 deletions schema/documents/base/maintainer_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,363 @@
// Copyright [2021] - [2022], AssetMantle Pte. Ltd. and the code contributors
// SPDX-License-Identifier: Apache-2.0

package base

import (
"github.com/AssetMantle/modules/schema/data"
baseData "github.com/AssetMantle/modules/schema/data/base"
"github.com/AssetMantle/modules/schema/documents"
"github.com/AssetMantle/modules/schema/ids"
baseIDs "github.com/AssetMantle/modules/schema/ids/base"
"github.com/AssetMantle/modules/schema/ids/constansts"
"github.com/AssetMantle/modules/schema/lists"
baseLists "github.com/AssetMantle/modules/schema/lists/base"
schemaProperties "github.com/AssetMantle/modules/schema/properties"
baseProperties "github.com/AssetMantle/modules/schema/properties/base"
"github.com/AssetMantle/modules/schema/properties/constants"
baseQualified "github.com/AssetMantle/modules/schema/qualified/base"
baseTypes "github.com/AssetMantle/modules/schema/types/base"
sdkTypes "github.com/cosmos/cosmos-sdk/types"
"reflect"
"testing"
)

var (
testImmutables = baseQualified.NewImmutables(baseLists.NewPropertyList(baseProperties.NewMesaProperty(baseIDs.NewStringID("ID1"), baseData.NewStringData("ImmutableData")), baseProperties.NewMetaProperty(constants.CreationHeightProperty.GetKey(), baseData.NewHeightData(baseTypes.NewHeight(1))), baseProperties.NewMetaProperty(constants.ExchangeRateProperty.GetKey(), baseData.NewDecData(sdkTypes.NewDec(int64(10)))), baseProperties.NewMetaProperty(constants.MakerOwnableIDProperty.GetKey(), baseData.NewIDData(baseIDs.NewOwnableID(baseIDs.NewStringID("MakerOwnableID")))), baseProperties.NewMetaProperty(constants.TakerOwnableIDProperty.GetKey(), baseData.NewIDData(baseIDs.NewOwnableID(baseIDs.NewStringID("TakerOwnableID")))), baseProperties.NewMetaProperty(constants.ExpiryHeightProperty.GetKey(), baseData.NewHeightData(baseTypes.NewHeight(100))), baseProperties.NewMetaProperty(constants.MakerOwnableSplitProperty.GetKey(), baseData.NewDecData(sdkTypes.NewDec(int64(10))))))
testMutables = baseQualified.NewMutables(baseLists.NewPropertyList(baseProperties.NewMesaProperty(baseIDs.NewStringID("ID2"), baseData.NewStringData("MutableData")), baseProperties.NewMetaProperty(constants.TakerIDProperty.GetKey(), baseData.NewIDData(baseIDs.PrototypeIdentityID())), baseProperties.NewMetaProperty(constants.MakerIDProperty.GetKey(), baseData.NewIDData(baseIDs.PrototypeIdentityID()))))
testPermissionsList = baseLists.NewIDList([]ids.ID{constansts.Mint, constansts.Add, constansts.Remove, constansts.Mutate, constansts.Renumerate, constansts.Burn}...)
testClassificationID = baseIDs.NewClassificationID(immutables, mutables)
testIdentityID = baseIDs.NewIdentityID(testClassificationID, testImmutables)
testMaintainer = NewMaintainer(testIdentityID, testClassificationID, testMutables.GetMutablePropertyList().GetPropertyIDList(), testPermissionsList)
)

func TestNewMaintainer(t *testing.T) {
type args struct {
identityID ids.IdentityID
maintainedClassificationID ids.ClassificationID
maintainedPropertyIDList lists.IDList
permissions lists.IDList
}
tests := []struct {
name string
args args
want documents.Maintainer
}{
{"+ve", args{testIdentityID, testClassificationID, testMutables.GetMutablePropertyList().GetPropertyIDList(), testPermissionsList}, maintainer{NewDocument(constansts.MaintainerClassificationID,
baseQualified.NewImmutables(baseLists.NewPropertyList(
baseProperties.NewMetaProperty(constants.IdentityIDProperty.GetKey(), baseData.NewIDData(testIdentityID)),
baseProperties.NewMetaProperty(constants.MaintainedClassificationIDProperty.GetKey(), baseData.NewIDData(testClassificationID)),
)),
baseQualified.NewMutables(baseLists.NewPropertyList(
baseProperties.NewMetaProperty(constants.MaintainedPropertiesProperty.GetKey(), baseData.NewListData(idListToDataList(testMutables.GetMutablePropertyList().GetPropertyIDList()))),
baseProperties.NewMetaProperty(constants.PermissionsProperty.GetKey(), baseData.NewListData(idListToDataList(testPermissionsList))),
)),
)}},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := NewMaintainer(tt.args.identityID, tt.args.maintainedClassificationID, tt.args.maintainedPropertyIDList, tt.args.permissions); !reflect.DeepEqual(got, tt.want) {
t.Errorf("NewMaintainer() = %v, want %v", got, tt.want)
}
})
}
}

func Test_idListToDataList(t *testing.T) {
type args struct {
idList lists.IDList
}
tests := []struct {
name string
args args
want lists.DataList
}{
{"+ve", args{testPermissionsList}, baseLists.NewDataList(baseData.NewIDData(constansts.Mint), baseData.NewIDData(constansts.Add), baseData.NewIDData(constansts.Remove), baseData.NewIDData(constansts.Mutate), baseData.NewIDData(constansts.Renumerate), baseData.NewIDData(constansts.Burn))},
{"+ve with nil", args{baseLists.NewIDList()}, baseLists.NewDataList()},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := idListToDataList(tt.args.idList); !reflect.DeepEqual(got, tt.want) {
t.Errorf("idListToDataList() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_CanAddMaintainer(t *testing.T) {
testMaintainer2 := NewMaintainer(testIdentityID, testClassificationID, testMutables.GetMutablePropertyList().GetPropertyIDList(), baseLists.NewIDList())
type fields struct {
Document documents.Document
}
tests := []struct {
name string
fields fields
want bool
}{
{"+ve", fields{testMaintainer}, true},
{"+ve", fields{testMaintainer2}, false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.CanAddMaintainer(); got != tt.want {
t.Errorf("CanAddMaintainer() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_CanBurnAsset(t *testing.T) {
testMaintainer2 := NewMaintainer(testIdentityID, testClassificationID, testMutables.GetMutablePropertyList().GetPropertyIDList(), baseLists.NewIDList())
type fields struct {
Document documents.Document
}
tests := []struct {
name string
fields fields
want bool
}{
{"+ve", fields{testMaintainer}, true},
{"+ve", fields{testMaintainer2}, false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.CanBurnAsset(); got != tt.want {
t.Errorf("CanBurnAsset() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_CanMintAsset(t *testing.T) {
testMaintainer2 := NewMaintainer(testIdentityID, testClassificationID, testMutables.GetMutablePropertyList().GetPropertyIDList(), baseLists.NewIDList())
type fields struct {
Document documents.Document
}
tests := []struct {
name string
fields fields
want bool
}{
{"+ve", fields{testMaintainer}, true},
{"+ve", fields{testMaintainer2}, false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.CanMintAsset(); got != tt.want {
t.Errorf("CanMintAsset() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_CanMutateMaintainer(t *testing.T) {
testMaintainer2 := NewMaintainer(testIdentityID, testClassificationID, testMutables.GetMutablePropertyList().GetPropertyIDList(), baseLists.NewIDList())
type fields struct {
Document documents.Document
}
tests := []struct {
name string
fields fields
want bool
}{
{"+ve", fields{testMaintainer}, true},
{"+ve", fields{testMaintainer2}, false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.CanMutateMaintainer(); got != tt.want {
t.Errorf("CanMutateMaintainer() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_CanRemoveMaintainer(t *testing.T) {
testMaintainer2 := NewMaintainer(testIdentityID, testClassificationID, testMutables.GetMutablePropertyList().GetPropertyIDList(), baseLists.NewIDList())
type fields struct {
Document documents.Document
}
tests := []struct {
name string
fields fields
want bool
}{
{"+ve", fields{testMaintainer}, true},
{"+ve", fields{testMaintainer2}, false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.CanRemoveMaintainer(); got != tt.want {
t.Errorf("CanRemoveMaintainer() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_CanRenumerateAsset(t *testing.T) {
testMaintainer2 := NewMaintainer(testIdentityID, testClassificationID, testMutables.GetMutablePropertyList().GetPropertyIDList(), baseLists.NewIDList())
type fields struct {
Document documents.Document
}
tests := []struct {
name string
fields fields
want bool
}{
{"+ve", fields{testMaintainer}, true},
{"+ve", fields{testMaintainer2}, false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.CanRenumerateAsset(); got != tt.want {
t.Errorf("CanRenumerateAsset() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_GetIdentityID(t *testing.T) {
testMaintainer2 := NewMaintainer(baseIDs.PrototypeIdentityID(), testClassificationID, testMutables.GetMutablePropertyList().GetPropertyIDList(), baseLists.NewIDList())
type fields struct {
Document documents.Document
}
tests := []struct {
name string
fields fields
want ids.IdentityID
}{
{"+ve", fields{testMaintainer}, testIdentityID},
{"+ve", fields{testMaintainer2}, baseIDs.PrototypeIdentityID()},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.GetIdentityID(); !reflect.DeepEqual(got, tt.want) {
t.Errorf("GetIdentityID() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_GetMaintainedClassificationID(t *testing.T) {
testMaintainer2 := NewMaintainer(testIdentityID, baseIDs.PrototypeClassificationID(), testMutables.GetMutablePropertyList().GetPropertyIDList(), baseLists.NewIDList())
type fields struct {
Document documents.Document
}
tests := []struct {
name string
fields fields
want ids.ClassificationID
}{
{"+ve", fields{testMaintainer}, testClassificationID},
{"+ve", fields{testMaintainer2}, baseIDs.PrototypeClassificationID()},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.GetMaintainedClassificationID(); !reflect.DeepEqual(got, tt.want) {
t.Errorf("GetMaintainedClassificationID() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_GetMaintainedProperties(t *testing.T) {
testMaintainer2 := NewMaintainer(testIdentityID, testClassificationID, baseQualified.NewMutables(baseLists.NewPropertyList()).GetMutablePropertyList().GetPropertyIDList(), baseLists.NewIDList())
type fields struct {
Document documents.Document
}
tests := []struct {
name string
fields fields
want data.ListData
}{
{"+ve", fields{testMaintainer}, testMaintainer.GetProperty(constants.MaintainedPropertiesProperty.GetID()).(schemaProperties.MetaProperty).GetData().(data.ListData)},
{"+ve", fields{testMaintainer2}, constants.MaintainedPropertiesProperty.GetData().(data.ListData)},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.GetMaintainedProperties(); !reflect.DeepEqual(got, tt.want) {
t.Errorf("GetMaintainedProperties() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_GetPermissions(t *testing.T) {
testMaintainer2 := NewMaintainer(testIdentityID, testClassificationID, testMutables.GetMutablePropertyList().GetPropertyIDList(), baseLists.NewIDList())
type fields struct {
Document documents.Document
}
tests := []struct {
name string
fields fields
want data.ListData
}{
{"+ve", fields{testMaintainer}, testMaintainer.GetProperty(constants.PermissionsProperty.GetID()).(schemaProperties.MetaProperty).GetData().(data.ListData)},
{"+ve", fields{testMaintainer2}, constants.PermissionsProperty.GetData().(data.ListData)},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.GetPermissions(); !reflect.DeepEqual(got, tt.want) {
t.Errorf("GetPermissions() = %v, want %v", got, tt.want)
}
})
}
}

func Test_maintainer_MaintainsProperty(t *testing.T) {
type fields struct {
Document documents.Document
}
type args struct {
propertyID ids.PropertyID
}
tests := []struct {
name string
fields fields
args args
want bool
}{
{"+ve", fields{testMaintainer}, args{baseProperties.NewMetaProperty(baseIDs.NewStringID("ID2"), baseData.NewStringData("MutableData")).GetID()}, true},
{"+ve", fields{testMaintainer}, args{baseProperties.NewMetaProperty(baseIDs.NewStringID("ID"), baseData.NewStringData("MutableData")).GetID()}, false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
maintainer := maintainer{
Document: tt.fields.Document,
}
if got := maintainer.MaintainsProperty(tt.args.propertyID); got != tt.want {
t.Errorf("MaintainsProperty() = %v, want %v", got, tt.want)
}
})
}
}
Loading