Unfortunately, the SDK does not support debugging revert errors with string messages - at least temporarily. This is because the SDK does not support decoding of Sway str
slices in the v0
Sway encoding scheme. This problem will be fixed soon once the v1
Sway encoding scheme is adopted.
But for now, if your Sway contract has a revert error with a string message like this:
fn test_function() -> bool {
require(false, "This is a revert error");
true
}
The SDK will throw an error that says:
expect(() => contract.functions.test_function().call()).rejects.toThrow(
'String slices can not be decoded from logs. Convert the slice to `str[N]` with `__to_str_array`'
);
It will not log out the message associated with the revert error. This can make debugging functions with multiple require statements difficult.
__to_str_array
You can work around this by using the __to_str_array
helper function to convert the str
slice to a string array:
fn test_function_with_str_array_message() -> bool {
require(false, __to_str_array("This is also a revert error"));
true
}
The SDK will log out the message associated with the revert error like so:
expect(() => contract.functions.test_function_with_str_array_message().call()).rejects.toThrow(
'The transaction reverted because a "require" statement has thrown "This is also a revert error".'
);
You can also work around this by using custom enums to represent the error messages. For example, you can create an enum like this:
enum Errors {
InvalidInput: (),
}
Then, you can use the enum in your contract like this:
fn test_function_with_custom_error() -> bool {
require(false, Errors::InvalidInput);
true
}
The SDK will log out the message associated with the revert error like so:
expect(() => contract.functions.test_function_with_custom_error().call()).rejects.toThrow(
'The transaction reverted because a "require" statement has thrown "InvalidInput".'
);