nns: ensure records with the same type are not repeated
Port https://github.com/nspcc-dev/neofs-contract/pull/170.
This commit is contained in:
parent
c9050cef4b
commit
8790602f69
2 changed files with 9 additions and 10 deletions
examples/nft-nd-nns
|
@ -359,8 +359,12 @@ func AddRecord(name string, typ RecordType, data string) {
|
||||||
tokenID := checkRecord(ctx, name, typ, data)
|
tokenID := checkRecord(ctx, name, typ, data)
|
||||||
recordsPrefix := getRecordsByTypePrefix(tokenID, name, typ)
|
recordsPrefix := getRecordsByTypePrefix(tokenID, name, typ)
|
||||||
var id byte
|
var id byte
|
||||||
records := storage.Find(ctx, recordsPrefix, storage.KeysOnly)
|
records := storage.Find(ctx, recordsPrefix, storage.ValuesOnly|storage.DeserializeValues)
|
||||||
for iterator.Next(records) {
|
for iterator.Next(records) {
|
||||||
|
r := iterator.Value(records).(RecordState)
|
||||||
|
if r.Name == name && r.Type == typ && r.Data == data {
|
||||||
|
panic("record already exists")
|
||||||
|
}
|
||||||
id++
|
id++
|
||||||
}
|
}
|
||||||
if id > maxRecordID {
|
if id > maxRecordID {
|
||||||
|
|
|
@ -232,11 +232,8 @@ func TestSetAddGetRecord(t *testing.T) {
|
||||||
c.Invoke(t, stackitem.NewArray([]stackitem.Item{}), "getRecords", "neo.com", int64(nns.A))
|
c.Invoke(t, stackitem.NewArray([]stackitem.Item{}), "getRecords", "neo.com", int64(nns.A))
|
||||||
c.Invoke(t, stackitem.Null{}, "addRecord", "neo.com", int64(nns.A), "1.2.3.4")
|
c.Invoke(t, stackitem.Null{}, "addRecord", "neo.com", int64(nns.A), "1.2.3.4")
|
||||||
c.Invoke(t, stackitem.NewArray([]stackitem.Item{stackitem.Make("1.2.3.4")}), "getRecords", "neo.com", int64(nns.A))
|
c.Invoke(t, stackitem.NewArray([]stackitem.Item{stackitem.Make("1.2.3.4")}), "getRecords", "neo.com", int64(nns.A))
|
||||||
c.Invoke(t, stackitem.Null{}, "addRecord", "neo.com", int64(nns.A), "1.2.3.4") // Duplicating record.
|
c.InvokeFail(t, "record already exists", "addRecord", "neo.com", int64(nns.A), "1.2.3.4") // Duplicating record.
|
||||||
c.Invoke(t, stackitem.NewArray([]stackitem.Item{
|
c.Invoke(t, stackitem.NewArray([]stackitem.Item{stackitem.Make("1.2.3.4")}), "getRecords", "neo.com", int64(nns.A))
|
||||||
stackitem.Make("1.2.3.4"),
|
|
||||||
stackitem.Make("1.2.3.4"),
|
|
||||||
}), "getRecords", "neo.com", int64(nns.A))
|
|
||||||
c.Invoke(t, stackitem.Null{}, "addRecord", "neo.com", int64(nns.AAAA), "2001:0201:1f1f:0000:0000:0100:11a0:11df")
|
c.Invoke(t, stackitem.Null{}, "addRecord", "neo.com", int64(nns.AAAA), "2001:0201:1f1f:0000:0000:0100:11a0:11df")
|
||||||
c.Invoke(t, stackitem.Null{}, "addRecord", "neo.com", int64(nns.CNAME), "nspcc.ru")
|
c.Invoke(t, stackitem.Null{}, "addRecord", "neo.com", int64(nns.CNAME), "nspcc.ru")
|
||||||
c.Invoke(t, stackitem.Null{}, "addRecord", "neo.com", int64(nns.TXT), "sometext")
|
c.Invoke(t, stackitem.Null{}, "addRecord", "neo.com", int64(nns.TXT), "sometext")
|
||||||
|
@ -265,10 +262,7 @@ func TestSetAddGetRecord(t *testing.T) {
|
||||||
c.Invoke(t, stackitem.NewArray([]stackitem.Item{stackitem.Make("nspcc.ru")}), "getRecords", "neo.com", int64(nns.CNAME))
|
c.Invoke(t, stackitem.NewArray([]stackitem.Item{stackitem.Make("nspcc.ru")}), "getRecords", "neo.com", int64(nns.CNAME))
|
||||||
c.Invoke(t, stackitem.Null{}, "deleteRecords", "neo.com", int64(nns.CNAME))
|
c.Invoke(t, stackitem.Null{}, "deleteRecords", "neo.com", int64(nns.CNAME))
|
||||||
c.Invoke(t, stackitem.NewArray([]stackitem.Item{}), "getRecords", "neo.com", int64(nns.CNAME))
|
c.Invoke(t, stackitem.NewArray([]stackitem.Item{}), "getRecords", "neo.com", int64(nns.CNAME))
|
||||||
c.Invoke(t, stackitem.NewArray([]stackitem.Item{
|
c.Invoke(t, stackitem.NewArray([]stackitem.Item{stackitem.Make("1.2.3.4")}), "getRecords", "neo.com", int64(nns.A))
|
||||||
stackitem.Make("1.2.3.4"),
|
|
||||||
stackitem.Make("1.2.3.4"),
|
|
||||||
}), "getRecords", "neo.com", int64(nns.A))
|
|
||||||
|
|
||||||
t.Run("SetRecord_compatibility", func(t *testing.T) {
|
t.Run("SetRecord_compatibility", func(t *testing.T) {
|
||||||
// tests are got from the NNS C# implementation and changed accordingly to non-native implementation behavior
|
// tests are got from the NNS C# implementation and changed accordingly to non-native implementation behavior
|
||||||
|
@ -331,6 +325,7 @@ func TestSetAddGetRecord(t *testing.T) {
|
||||||
c.InvokeFail(t, "", "addRecord", args...)
|
c.InvokeFail(t, "", "addRecord", args...)
|
||||||
} else {
|
} else {
|
||||||
c.Invoke(t, stackitem.Null{}, "addRecord", args...)
|
c.Invoke(t, stackitem.Null{}, "addRecord", args...)
|
||||||
|
c.Invoke(t, stackitem.Null{}, "deleteRecords", "neo.com", int64(testCase.Type)) // clear records after test to avoid duplicating records.
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue