Skip to content

Commit

Permalink
itest: account for new uni ID proof type field when syncing
Browse files Browse the repository at this point in the history
  • Loading branch information
ffranr committed Oct 9, 2023
1 parent 9bce95e commit 641fd47
Showing 1 changed file with 32 additions and 11 deletions.
43 changes: 32 additions & 11 deletions itest/universe_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,13 @@ import (
"github.com/btcsuite/btcd/btcec/v2"
"github.com/btcsuite/btcd/btcec/v2/schnorr"
tap "github.com/lightninglabs/taproot-assets"
"github.com/lightninglabs/taproot-assets/asset"
"github.com/lightninglabs/taproot-assets/fn"
"github.com/lightninglabs/taproot-assets/mssmt"
"github.com/lightninglabs/taproot-assets/taprpc"
"github.com/lightninglabs/taproot-assets/taprpc/mintrpc"
unirpc "github.com/lightninglabs/taproot-assets/taprpc/universerpc"
"github.com/lightninglabs/taproot-assets/universe"
"github.com/lightningnetwork/lnd/lntest/wait"
"github.com/stretchr/testify/require"
"golang.org/x/exp/maps"
Expand Down Expand Up @@ -110,7 +112,12 @@ func testUniverseSync(t *harnessTest) {
}
}()

srcRoot, ok := universeRoots.UniverseRoots[uniKey]
// Construct universe namespace.
proofType, err := tap.UnmarshalUniProofType(newRoot.Id.ProofType)
require.NoError(t.t, err)
uniNamespace := fmt.Sprintf("%s-%s", proofType, uniKey)

srcRoot, ok := universeRoots.UniverseRoots[uniNamespace]
require.True(t.t, ok)
require.True(t.t, AssertUniverseRootEqual(srcRoot, newRoot))
}
Expand All @@ -130,8 +137,7 @@ func testUniverseSync(t *harnessTest) {
uniRoots := maps.Values(universeRoots.UniverseRoots)
uniIDs := fn.Map(uniRoots, func(root *unirpc.UniverseRoot) *unirpc.ID {
return root.Id
},
)
})
AssertUniverseKeysEqual(t.t, uniIDs, t.tapd, bob)
AssertUniverseLeavesEqual(t.t, uniIDs, t.tapd, bob)

Expand Down Expand Up @@ -211,6 +217,7 @@ func testUniverseSync(t *harnessTest) {
Id: &unirpc.ID_AssetId{
AssetId: firstAssetID,
},
ProofType: unirpc.ProofType_ISSUANCE,
},
})
require.NoError(t.t, err)
Expand Down Expand Up @@ -282,21 +289,29 @@ func testUniverseREST(t *harnessTest) {

// Simple assets are keyed by their asset ID.
for _, simpleAsset := range rpcSimpleAssets {
assetID := hex.EncodeToString(simpleAsset.AssetGenesis.AssetId)
require.Contains(t.t, roots.UniverseRoots, assetID)
// Ensure that the universe root set contains issuance roots for
// all of our assets.
var assetID asset.ID
copy(assetID[:], simpleAsset.AssetGenesis.AssetId)
uniID := universe.Identifier{
AssetID: assetID,
ProofType: universe.ProofTypeIssuance,
}
uniIDStr := uniID.String()
require.Contains(t.t, roots.UniverseRoots, uniIDStr)

require.Equal(
t.t, simpleAsset.AssetGenesis.Name,
roots.UniverseRoots[assetID].AssetName,
roots.UniverseRoots[uniIDStr].AssetName,
)

// Query the specific root to make sure we get the same result.
assetRoot, err := getJSON[*unirpc.QueryRootResponse](
assetRoots, err := getJSON[*unirpc.QueryRootResponse](
fmt.Sprintf("%s/roots/asset-id/%s", urlPrefix, assetID),
)
require.NoError(t.t, err)
require.True(t.t, AssertUniverseRootEqual(
roots.UniverseRoots[assetID], assetRoot.AssetRoot,
roots.UniverseRoots[uniIDStr], assetRoots.IssuanceRoot,
))
}

Expand All @@ -309,7 +324,12 @@ func testUniverseREST(t *harnessTest) {
groupKey := issuableAsset.AssetGroup.TweakedGroupKey
groupKeyHash := sha256.Sum256(groupKey[1:])
groupKeyID := hex.EncodeToString(groupKeyHash[:])
require.Contains(t.t, roots.UniverseRoots, groupKeyID)

// Construct universe namespace using the group key ID.
namespace := fmt.Sprintf(
"%s-%s", universe.ProofTypeTransfer, groupKeyID,
)
require.Contains(t.t, roots.UniverseRoots, namespace)

// Query the specific root to make sure we get the same result.
// Rather than use the hash above, the API exposes the
Expand All @@ -321,9 +341,10 @@ func testUniverseREST(t *harnessTest) {
assetRoot, err := getJSON[*unirpc.QueryRootResponse](queryURI)
require.NoError(t.t, err)

uniRoot, foundRoot := roots.UniverseRoots[namespace]
require.True(t.t, foundRoot)
require.True(t.t, AssertUniverseRootEqual(
roots.UniverseRoots[groupKeyID],
assetRoot.AssetRoot,
uniRoot, assetRoot.TransferRoot,
))
}
}
Expand Down

0 comments on commit 641fd47

Please sign in to comment.