mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			73 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env bash
 | |
| 
 | |
| #------------------------------------------------------------------------------
 | |
| # Bash script to execute the Solidity tests.
 | |
| #
 | |
| # The documentation for solidity is hosted at:
 | |
| #
 | |
| #     https://solidity.readthedocs.org
 | |
| #
 | |
| # ------------------------------------------------------------------------------
 | |
| # This file is part of solidity.
 | |
| #
 | |
| # solidity is free software: you can redistribute it and/or modify
 | |
| # it under the terms of the GNU General Public License as published by
 | |
| # the Free Software Foundation, either version 3 of the License, or
 | |
| # (at your option) any later version.
 | |
| #
 | |
| # solidity is distributed in the hope that it will be useful,
 | |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| # GNU General Public License for more details.
 | |
| #
 | |
| # You should have received a copy of the GNU General Public License
 | |
| # along with solidity.  If not, see <http://www.gnu.org/licenses/>
 | |
| #
 | |
| # (c) 2016 solidity contributors.
 | |
| #------------------------------------------------------------------------------
 | |
| 
 | |
| set -e
 | |
| 
 | |
| REPO_ROOT="$(dirname "$0")"/..
 | |
| 
 | |
| echo "Running commandline tests..."
 | |
| "$REPO_ROOT/test/cmdlineTests.sh"
 | |
| 
 | |
| echo "Checking that StandardToken.sol, owned.sol and mortal.sol produce bytecode..."
 | |
| output=$("$REPO_ROOT"/build/solc/solc --bin "$REPO_ROOT"/std/*.sol 2>/dev/null | grep "ffff" | wc -l)
 | |
| test "${output//[[:blank:]]/}" = "3"
 | |
| 
 | |
| # This conditional is only needed because we don't have a working Homebrew
 | |
| # install for `eth` at the time of writing, so we unzip the ZIP file locally
 | |
| # instead.  This will go away soon.
 | |
| if [[ "$OSTYPE" == "darwin"* ]]; then
 | |
|     ETH_PATH="$REPO_ROOT/eth"
 | |
| else
 | |
|     ETH_PATH="eth"
 | |
| fi
 | |
| 
 | |
| # This trailing ampersand directs the shell to run the command in the background,
 | |
| # that is, it is forked and run in a separate sub-shell, as a job,
 | |
| # asynchronously. The shell will immediately return the return status of 0 for
 | |
| # true and continue as normal, either processing further commands in a script
 | |
| # or returning the cursor focus back to the user in a Linux terminal.
 | |
| $ETH_PATH --test -d /tmp/test &
 | |
| 
 | |
| # Wait until the IPC endpoint is available.  That won't be available instantly.
 | |
| # The node needs to get a little way into its startup sequence before the IPC
 | |
| # is available and is ready for the unit-tests to start talking to it.
 | |
| while [ ! -S /tmp/test/geth.ipc ]; do sleep 2; done
 | |
| echo "--> IPC available."
 | |
| 
 | |
| # And then run the Solidity unit-tests (once without optimization, once with),
 | |
| # pointing to that IPC endpoint.
 | |
| echo "--> Running tests without optimizer..."
 | |
|   "$REPO_ROOT"/build/test/soltest -- --ipcpath /tmp/test/geth.ipc && \
 | |
|   echo "--> Running tests WITH optimizer..." && \
 | |
|   "$REPO_ROOT"/build/test/soltest -- --optimize --ipcpath /tmp/test/geth.ipc
 | |
| ERROR_CODE=$?
 | |
| pkill eth || true
 | |
| sleep 4
 | |
| pgrep eth && pkill -9 eth || true
 | |
| exit $ERROR_CODE
 |