Hướng dẫn kiểm thử
Last updated
Last updated
Trong phần này, chúng tôi sẽ giới thiệu cách kiểm thử các hợp đồng thông minh. Các giao dịch trên blockchain không thể hoàn tác. Do đó, việc kiểm thử hợp đồng thông minh của bạn trước khi triển khai có vai trò rất quan trọng.
Truffle cung cấp công cụ kiểm thử tự động. Công cụ này cho phép bạn viết các kiểm thử đơn giản và dễ quản lý theo hai cách khác nhau:
Bằng Javascript
và TypeScript
, để thực hiện kiểm thử các hợp đồng từ bên ngoài, giống như ứng dụng.
Bằng Solidity
, để thực hiện kiểm thử trước các hợp đồng, trong các tình huống không có hệ điều hành hoặc ứng dụng.
Chúng ta sẽ làm theo để tạo và triển khai một hợp đồng. Tuy nhiên, trước khi triển khai, chúng ta sẽ thêm một hàm thiết lập setGreet
vào hợp đồng nhằm mục đích kiểm thử. Mã nguồn được đưa ra như sau.
LƯU Ý: Chúng tôi đã thực hiện một số sửa đổi với hợp đồng nhằm mục đích kiểm thử.
Dưới đây là mã nguồn của hợp đồng KlaytnGreeting.
Chúng ta sẽ kiểm thử 1) hàm greet()
để xem nó có trả về thông báo "Hello, Klaytn" một cách chính xác không, 2) hàm setGreet()
để xem nó có thiết lập thông báo chào mừng mới một cách chính xác không và hoàn ngược khi tài khoản không phải là chủ sở hữu cố gắng cập nhật thông báo chào mừng không.
Đầu tiên, chúng ta sẽ cài đặt thư viện công cụ khẳng định Chai (hoặc bất kỳ thư viện công cụ khẳng định khác bạn sử dụng) cho các khẳng định chung và thư viện công cụ khẳng định truffle cho các khẳng định trong hợp đồng thông minh.
Kiểm thử bằng Solidity có thể trực quan hơn một chút so với kiểm thử bằng JavaScript. Các hợp đồng kiểm thử Solidity được lưu trữ cùng với các kiểm thử JavaScript dưới dạng tập tin .sol.
Tạo một tập tin có tên là TestKlaytnGreeting.sol
trong thư mục test
. Bộ công cụ Truffle cung cấp các thư viện hỗ trợ kiểm thử, vì vậy chúng ta cần nhập các thư viện này. Hãy cùng xem ví dụ kiểm thử bằng Solidity dưới đây:
Assert : Cho phép chúng ta truy cập vào các hàm kiểm thử khác nhau, như Assert.equals()
, Assert.greaterThan()
, v.v.
DeployedAddresses : Mỗi khi bạn thay đổi hợp đồng của mình, bạn phải triển khai lại hợp đồng để có một địa chỉ mới. Bạn có thể lấy các địa chỉ hợp đồng đã triển khai thông qua thư viện này.
Bây giờ, hãy cùng viết mã kiểm thử.
Chạy mã kiểm thử Solidity của bạn.
Đã xảy ra lỗi. Hãy kiểm tra thông báo lỗi,Error: greeting message should match (Tested: Hello, Klaytn, Against: Hello Klaytn)
. Tôi để ý thấy thiếu dấu ',(comma)'
ở bộ nhớ chuỗi expectedGreet = "Hello Klaytn".
Sửa mã và chạy thử lần nữa.
Xin chúc mừng! Bạn đã kiểm thử thành công.
Hãy tạo một tập tin và đặt tên là 0_KlaytnGreeting.js
dưới thư mục test
.
Mã kiểm thử là:
Sử dụng contract()
thay vì describe()
Về mặt cấu trúc, mã kiểm thử của Truffle không nên khác biệt nhiều so với mã kiểm thử thông thường của Mocha. Kiểm thử của bạn nên chứa mã giúp Mocha nhận ra đó là kiểm thử tự động. Khác biệt giữa kiểm thử Mocha và kiểm thử Truffle là việc sử dụng hàm contract().\ LƯU Ý sử dụng hàm contract()
và sử dụng mảng tài khoảns
để chỉ định các tài khoản Klaytn đang có sẵn.
Tóm tắt hợp đồng trong các kiểm thử
Vì Truffle không có phương pháp nào để phát hiện hợp đồng nào bạn cần tương tác trong suốt quá trình kiểm thử, bạn phải nêu chi tiết hợp đồng một cách rõ ràng. Một trong các giải pháp là sử dụng phương pháp artifacts.require()
.
cú pháp it
Cú pháp này thể hiện mỗi trường hợp kiểm thử cùng với mô tả. Mô tả sẽ được in ra trên bảng điều khiển khi chạy kiểm thử.
thư viện truffle-assertion
Thư viện này cho phép bạn dễ dàng kiểm thử các trường hợp hoàn ngược hoặc các lỗi khác bằng cách sử dụng hàm truffleAssert.reverts()
và truffleAssert.fails()
.
Kết quả phải như sau:
Xin chúc mừng! Bạn đã kiểm thử thành công.
Bạn có thể lựa chọn tập tin kiểm thử cần thực thi.
Truffle sử dụng công cụ kiểm thử và thư viện công cụ khẳng định để cung cấp công cụ vững chắc cho kiểm thử bằng JavaScript. Kiểm thử bằng JavaScript linh hoạt hơn và cho phép bạn viết các kiểm thử phức tạp hơn.
Nếu bạn không quen thuộc với kiểm thử đơn vị Mocha
, vui lòng tham khảo .
Để biết thêm thông tin, vui lòng tham khảo và .