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

feat(tokenGrantKycTransaction): Implement TokenRevokeKycTransaction E2E tests: TCK #302

Open
wants to merge 8 commits into
base: main
Choose a base branch
from
1 change: 0 additions & 1 deletion .prettierrc
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,3 @@
"arrowParens": "always",
"endOfLine": "lf"
}

40 changes: 20 additions & 20 deletions docs/test-specifications/token-service/TokenRevokeKycTransaction.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ Each test within the test specification is linked to one of the properties withi

https://docs.hedera.com/hedera/sdks-and-apis/sdks/token-service/disable-kyc-account-flag

**TokenGrantKyc protobufs:**
**TokenRevokeKyc protobufs:**

https://github.com/hashgraph/hedera-protobufs/blob/main/services/token_revoke_kyc.proto

Expand Down Expand Up @@ -54,19 +54,19 @@ The tests contained in this specification will assume that a valid account has b

| Test no | Name | Input | Expected response | Implemented (Y/N) |
|---------|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|-------------------|
| 1 | Revokes KYC of a token to an account | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token revokes KYC to the account. | N |
| 2 | Revokes KYC of a token that doesn't exist to an account | tokenId="123.456.789", accountId=<CREATED_ACCOUNT_ID> | The token KYC revoke fails with an INVALID_TOKEN_ID response code from the network. | N |
| 3 | Revokes KYC of a token with an empty token ID to an account | tokenId="", accountId=<CREATED_ACCOUNT_ID> | The token KYC revoke fails with an SDK internal error. | N |
| 4 | Revokes KYC of a token with no token ID to an account | accountId=<CREATED_ACCOUNT_ID> | The token KYC revoke fails with an INVALID_TOKEN_ID response code from the network. | N |
| 5 | Revokes KYC of a deleted token to an account | tokenId=<DELETED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<DELETED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an TOKEN_WAS_DELETED response code from the network. | N |
| 6 | Revokes KYC of a token to an account without signing with the token's KYC key | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID> | The token KYC revoke fails with an INVALID_SIGNATURE response code from the network. | N |
| 7 | Revokes KYC of a token to an account but signs with the the token's admin key | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_ADMIN_KEY>] | The token KYC revoke fails with an INVALID_SIGNATURE response code from the network. | N |
| 8 | Revokes KYC of a token to an account but signs with an incorrect private key | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<INCORRECT_VALID_PRIVATE_KEY>] | The token KYC revoke fails with an INVALID_SIGNATURE response code from the network. | N |
| 9 | Revokes KYC of a token with no KYC key to an account | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID> | The token KYC revoke fails with an TOKEN_HAS_NO_KYC_KEY response code from the network. | N |
| 10 | Revokes KYC of a token to an account that doesn't have KYC | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token revokes KYC to the account. | N |
| 11 | Revokes KYC of a token to an account that is not associated with the token | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an TOKEN_NOT_ASSOCIATED_TO_ACCOUNT response code from the network. | N |
| 12 | Revokes KYC of a paused token to an account | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an TOKEN_IS_PAUSED response code from the network. | N |
| 13 | Revokes KYC of a token to a frozen account | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an ACCOUNT_FROZEN_FOR_TOKEN response code from the network. | N |
| 1 | Revokes KYC of a token to an account | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token revokes KYC to the account. | Y |
| 2 | Revokes KYC of a token that doesn't exist to an account | tokenId="123.456.789", accountId=<CREATED_ACCOUNT_ID> | The token KYC revoke fails with an INVALID_TOKEN_ID response code from the network. | Y |
| 3 | Revokes KYC of a token with an empty token ID to an account | tokenId="", accountId=<CREATED_ACCOUNT_ID> | The token KYC revoke fails with an SDK internal error. | Y |
| 4 | Revokes KYC of a token with no token ID to an account | accountId=<CREATED_ACCOUNT_ID> | The token KYC revoke fails with an INVALID_TOKEN_ID response code from the network. | Y |
| 5 | Revokes KYC of a deleted token to an account | tokenId=<DELETED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<DELETED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an TOKEN_WAS_DELETED response code from the network. | Y |
| 6 | Revokes KYC of a token to an account without signing with the token's KYC key | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID> | The token KYC revoke fails with an INVALID_SIGNATURE response code from the network. | Y |
| 7 | Revokes KYC of a token to an account but signs with the the token's admin key | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_ADMIN_KEY>] | The token KYC revoke fails with an INVALID_SIGNATURE response code from the network. | Y |
| 8 | Revokes KYC of a token to an account but signs with an incorrect private key | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<INCORRECT_VALID_PRIVATE_KEY>] | The token KYC revoke fails with an INVALID_SIGNATURE response code from the network. | Y |
| 9 | Revokes KYC of a token with no KYC key to an account | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID> | The token KYC revoke fails with an TOKEN_HAS_NO_KYC_KEY response code from the network. | Y |
| 10 | Revokes KYC of a token to an account that doesn't have KYC | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token revokes KYC to the account. | Y |
| 11 | Revokes KYC of a token to an account that is not associated with the token | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an TOKEN_NOT_ASSOCIATED_TO_ACCOUNT response code from the network. | Y |
| 12 | Revokes KYC of a paused token to an account | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an TOKEN_IS_PAUSED response code from the network. | Y |
| 13 | Revokes KYC of a token to a frozen account | tokenId=<CREATED_TOKEN_ID>, accountId=<CREATED_ACCOUNT_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an ACCOUNT_FROZEN_FOR_TOKEN response code from the network. | Y |

#### JSON Request Example

Expand Down Expand Up @@ -103,12 +103,12 @@ The tests contained in this specification will assume that a valid account has b

- The ID of the account to which to revoke KYC.

| Test no | Name | Input | Expected response | Implemented (Y/N) |
|---------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------|
| 1 | Revokes KYC of a token to an account that doesn't exist | tokenId=<CREATED_TOKEN_ID>, accountId="123.456.789", commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an INVALID_ACCOUNT_ID response code from the network. | N |
| 2 | Revokes KYC of a token to an empty account ID | tokenId=<CREATED_TOKEN_ID>, accountId="", commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an SDK internal error. | N |
| 3 | Revokes KYC of a token to an account with no account ID | tokenId=<CREATED_TOKEN_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an INVALID_TOKEN_ID response code from the network. | N |
| 4 | Revokes KYC of a token to a deleted account | tokenId=<CREATED_TOKEN_ID>, accountId=<DELETED_ACCOUNT_ID>, commonTransactionParams.signers=[<DELETED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an ACCOUNT_WAS_DELETED response code from the network. | N |
| Test no | Name | Input | Expected response | Implemented (Y/N) |
|---------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-------------------|
| 1 | Revokes KYC of a token to an account that doesn't exist | tokenId=<CREATED_TOKEN_ID>, accountId="123.456.789", commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an INVALID_ACCOUNT_ID response code from the network. | Y |
| 2 | Revokes KYC of a token to an empty account ID | tokenId=<CREATED_TOKEN_ID>, accountId="", commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an SDK internal error. | Y |
| 3 | Revokes KYC of a token to an account with no account ID | tokenId=<CREATED_TOKEN_ID>, commonTransactionParams.signers=[<CREATED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an INVALID_ACCOUNT_ID response code from the network. | Y |
| 4 | Revokes KYC of a token to a deleted account | tokenId=<CREATED_TOKEN_ID>, accountId=<DELETED_ACCOUNT_ID>, commonTransactionParams.signers=[<DELETED_TOKEN_KYC_KEY>] | The token KYC revoke fails with an ACCOUNT_DELETED response code from the network. | Y |

#### JSON Request Example

Expand Down
6 changes: 6 additions & 0 deletions src/services/MirrorNodeClient.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,12 @@ class MirrorNodeClient {
const url = `${this.mirrorNodeRestUrl}/api/v1/tokens/${tokenId}`;
return retryOnError(async () => fetchData(url));
}

// TODO: Get mirror node interface with OpenAPI
async getTokenRelationships(accountId: string) {
const url = `${this.mirrorNodeRestUrl}/api/v1/accounts/${accountId}/tokens`;
return retryOnError(async () => fetchData(url));
}
}

export default new MirrorNodeClient();
Loading