시가총액: $2.8167T -5.61%
거래량(24시간): $179.5196B 61.64%
공포와 탐욕 지수:

38 - 두려움

  • 시가총액: $2.8167T -5.61%
  • 거래량(24시간): $179.5196B 61.64%
  • 공포와 탐욕 지수:
  • 시가총액: $2.8167T -5.61%
암호화
주제
암호화
소식
cryptostopics
비디오
최고 암호화

언어 선택

언어 선택

통화 선택

암호화
주제
암호화
소식
cryptostopics
비디오

스마트 계약을 배포하기 전에 테스트하는 방법은 무엇입니까? (하드햇&송로버섯 사용)

Set up local dev with Node.js, Hardhat/Truffle, write unit tests using Mocha/Chai or Truffle’s framework, run Slither/Solhint/MythX, fork mainnet, and never skip testing—even for ERC-20s.

2026/01/26 05:20

로컬 개발 환경 설정

1. Node.js와 npm을 설치하여 Hardhat 및 Truffle 툴체인과의 호환성을 보장합니다.

2. npm init를 사용하여 새 프로젝트를 초기화하고 npm install --save-dev hardhat을 통해 Hardhat을 설치합니다.

3. Truffle의 경우 npm install -g truffle을 실행하고 truffle init를 사용하여 상용구를 생성합니다.

4. 확인을 위해 네트워크, 계정, Solidity 컴파일러 버전 및 Etherscan API 키를 지정하도록 hardhat.config.js를 구성합니다.

5. 로컬 Ganache 또는 Hardhat Network 엔드포인트를 포함하여 일치하는 네트워크 정의로 truffle-config.js를 설정합니다.

포괄적인 단위 테스트 작성

1. Hardhat 프로젝트의 test/ 디렉터리에 있는 JavaScript 또는 TypeScript 파일을 사용하여 Mocha 및 Chai로 테스트 사례를 정의합니다.

2. 각 테스트 전에 wait ethers.getContractFactory를 사용하여 계약 아티팩트를 가져오고 배포() 를 통해 인스턴스를 배포합니다.

3. 오류 조건에 대해 Expect(...).to.equal(...) 또는 wait Expect(...).to.be.revertedWith(...)를 사용하여 예상된 동작을 확인하십시오.

4. Truffle에서 contract() 블록을 사용하여 test/*.js 에 테스트를 작성하고 OpenZeppelin 테스트 도우미에서 Assert 또는 ExpectEvent를 작성합니다.

5. 역할 및 권한을 모의하여 값이 없는 전송, 재진입 시도, 무단 액세스와 같은 극단적인 사례를 처리합니다.

정적 분석 및 보안 검사 실행

1. Python 종속 항목을 설치하고 slither를 실행하여 Slither를 CI 파이프라인에 통합합니다 . --solc-remaps '@openzeppelin=node_modules/@openzeppelin' .

2. npm install solhint --save-dev 를 사용하여 스타일 및 보안 관련 안티 패턴을 감지하고 .solhint.json 에서 규칙을 구성하는 Solhint를 추가합니다.

3. 테스트 실행 중에 온체인 취약성 스캔을 수행하려면 Hardhat 플러그인 @mythx/hardhat-mythx 를 통해 MythX를 실행하세요.

4. 메인넷 배포 전에 etherscan-verify 플러그인을 사용하여 소스 코드가 바이트코드와 일치하는지 확인하세요.

5. 사용자 지정 수정자와 상속 계층을 수동으로 감사하여 onlyOwner , whenNotPaused 또는 유사한 가드가 모든 진입점에서 일관되게 작동하는지 확인합니다.

메인넷 조건 시뮬레이션

1. 라이브 상태를 복제하기 위해 Alchemy 또는 Infura 엔드포인트를 가리키는 Hardhat의 --fork 플래그를 사용하여 Ethereum 메인넷을 포크합니다.

2. 포크된 네트워크에 계약을 배포하고 Uniswap 또는 Aave와 같은 실제 DeFi 프로토콜과 상호 작용하여 통합 논리를 검증합니다.

3. --network mainnet-fork 와 함께 Truffle의 콘솔 명령을 사용하여 임시 호출을 실행하고 스토리지 레이아웃을 검사합니다.

4. 고부하 시나리오에서 기능을 트리거하고 OOG 오류로 인해 되돌리기가 발생하지 않는지 확인하여 가스 사용량 급증을 시뮬레이션합니다.

5. evm_increaseTimeevm_mine RPC 호출을 사용하여 블록 타임스탬프를 향상시켜 타임스탬프 종속 논리를 확인합니다.

자주 묻는 질문

Q: Hardhat 프로젝트에서 Truffle 테스트 파일을 재사용할 수 있습니까? 예, 대부분의 Truffle 스타일 JavaScript 테스트는 약간의 조정 후에 Hardhat에서 실행될 수 있습니다. Artifacts.require를 ethers.getContractFactory 로 교체하고 Chai 기대치에 맞게 어설션 구문을 업데이트하세요.

Q: Hardhat은 실제 ETH 잔액을 사용한 테스트를 지원합니까? Hardhat Network는 계정 구성을 통해 초기 잔액 설정을 지원합니다. 외부 수도꼭지 없이 자금 지원 상호 작용을 시뮬레이션하기 위해 테스트 계정에 1000 ETH를 할당할 수 있습니다.

Q: 계약에서 발생하는 이벤트를 어떻게 테스트합니까? Hardhat에서는 Expect(tx).to.emit(contract, 'EventName').withArgs(arg1, arg2) 를 사용하세요. Truffle에서는 ExpectEvent.inTransaction(tx, Contract, 'EventName', { arg1, arg2 }) 를 사용하세요.

Q: 내 계약이 단순한 ERC-20인 경우 테스트를 건너뛰어도 안전합니까? 아니요. 표준을 준수하는 토큰이라도 전송 제한, 발행 일시 중지 가능성, 교환 또는 스테이킹 계약과의 상호 작용에 대한 검증이 필요합니다. 테스트를 생략하면 되돌릴 수 없는 잠금 또는 인플레이션 버그가 발생할 위험이 있습니다.

부인 성명:info@kdj.com

제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!

본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.

관련 지식

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

2026-01-18 13:19:39

LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...

안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?

안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?

2026-01-20 22:20:26

EIP-712 개요 및 핵심 목적 1. EIP-712는 이더리움 애플리케이션에서 형식화된 구조화된 데이터 해싱 및 서명에 대한 표준을 정의합니다. 2. 서명 요청 시 원시 16진수 문자열 대신 사람이 읽을 수 있는 도메인 및 메시지 필드를 지갑에 표시할 수 있습니다. ...

새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?

새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?

2026-01-24 21:00:23

계약 상호 작용 요구 사항 이해 1. 대부분의 에어드롭 캠페인은 Ethereum, Arbitrum 또는 Base와 같은 지원되는 블록체인에 배포된 스마트 계약과의 직접적인 상호 작용을 요구합니다. 2. 상호 작용에는 일반적으로 dApp 인터페이스에 연결된 지갑을 사용하...

보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?

보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?

2026-01-21 07:59:57

온체인 모니터링 도구 1. Etherscan 및 Blockscout와 같은 블록체인 탐색기를 사용하면 계약 바이트 코드, 트랜잭션 로그 및 내부 호출을 실시간으로 검사할 수 있습니다. 2. 온체인 데이터를 신뢰하기 전에 계약 확인 상태를 확인해야 합니다. 확인되지 않은...

자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?

자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?

2026-01-26 08:59:35

스마트 계약 배포 이해 1. 개발자는 가스 효율성 및 보안 요구 사항을 기반으로 Ethereum, Polygon 또는 Arbitrum과 같은 호환 가능한 블록체인 플랫폼을 선택해야 합니다. 2. Solidity는 특히 반복 또는 조건부 이체를 위한 결제 자동화 로직 작...

OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?

OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?

2026-01-18 11:19:49

OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

2026-01-18 13:19:39

LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...

안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?

안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?

2026-01-20 22:20:26

EIP-712 개요 및 핵심 목적 1. EIP-712는 이더리움 애플리케이션에서 형식화된 구조화된 데이터 해싱 및 서명에 대한 표준을 정의합니다. 2. 서명 요청 시 원시 16진수 문자열 대신 사람이 읽을 수 있는 도메인 및 메시지 필드를 지갑에 표시할 수 있습니다. ...

새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?

새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?

2026-01-24 21:00:23

계약 상호 작용 요구 사항 이해 1. 대부분의 에어드롭 캠페인은 Ethereum, Arbitrum 또는 Base와 같은 지원되는 블록체인에 배포된 스마트 계약과의 직접적인 상호 작용을 요구합니다. 2. 상호 작용에는 일반적으로 dApp 인터페이스에 연결된 지갑을 사용하...

보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?

보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?

2026-01-21 07:59:57

온체인 모니터링 도구 1. Etherscan 및 Blockscout와 같은 블록체인 탐색기를 사용하면 계약 바이트 코드, 트랜잭션 로그 및 내부 호출을 실시간으로 검사할 수 있습니다. 2. 온체인 데이터를 신뢰하기 전에 계약 확인 상태를 확인해야 합니다. 확인되지 않은...

자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?

자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?

2026-01-26 08:59:35

스마트 계약 배포 이해 1. 개발자는 가스 효율성 및 보안 요구 사항을 기반으로 Ethereum, Polygon 또는 Arbitrum과 같은 호환 가능한 블록체인 플랫폼을 선택해야 합니다. 2. Solidity는 특히 반복 또는 조건부 이체를 위한 결제 자동화 로직 작...

OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?

OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?

2026-01-18 11:19:49

OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...

모든 기사 보기

User not found or password invalid

Your input is correct