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/dirtycheck #73

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open

Feat/dirtycheck #73

wants to merge 3 commits into from

Conversation

villesundell
Copy link
Contributor

This adds sanity check on the GIT repository's state, and also some misc stuff which needs to be committed now ( :D )

Now the script accepts --gas-price argument in Gweis, defaulting to 30.
Gweis were chosen over weis, because with weis user can accidentally create
too cheap transactions which would lead to many pending (and never mined)
transactions (most of the tools report gas in Gwei).
Now, if the script sees that the repository is not clean (not committed),
it does not proceed. Also, it will abort on non-master branches (by default,
possible to skip by using ICO_DEPLOY_ANYWAY env), and also it will abort if
you haven't pulled for a week.

The deployment script is also adding the commit hash to the source verified
by Etherscan.

Also added crowdsales/*.py to .gitignore for easier tracking of changes.
@villesundell villesundell requested a review from jsbueno October 11, 2017 16:09
@@ -170,7 +171,7 @@ def main(chain, address, token, csv_file, limit, start_from, issuer_address, add

transaction = {
"from": address,
"gasPrice": int(web3.eth.gasPrice * 1.5)
"gasPrice": gas_price * 1000000000
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yep - it all seems good. - ztane have placed some comments already.

But these numbers with a lot of zeros are really hard to read correctly, and they are very critical - I'd suggest creating a global constant of one million - ie - a line in the beggining of the file like MILLION = int(10e6)

and them write these gas_price expressions as: gasprice * 100 * MILLION
( int(10e8) would work, of course, but I find 100 * MILLION more readable)

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have totally different view on this, even though it's a rather small matter. I would say having constant like MILLION = int(10e6) is not only not correct (10e6 is actually 10**7 => 10 millions) but also doesn't really improve the readability of the code.

The context of this part of code is to convert gas_price from wei to gigawei. So the thing that developers really care about is how many 0 there are, which is the reason why we can say 1000000000 is a hard number to read => easy to make mistake. And for that reason alone it's best to use exponentiation.

And if you want to take it a little bit further, then you can define an utility function like:

def wei_to_gwei(price):
    return price * 10 ** 9  # or price * (10 ** 9) if you don't trust your memory on operator precedence 

then it's readable, understandable, reusable and testable.

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would not say it is small matter - and neither that it is "totally different" view. The major problem, of course is reading the zeros. I agree that putting the exponentiation directly will make the number of zeros more apparent (and less prone to subtle catastrophic mistakes as the one I just made, of writting 10e6 thinking about 10 ** 6)

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is the other matter that int(1e6) is not a compile-time constant, unlike 10 ** 6.

Copy link

@jsbueno jsbueno left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Other than the comment I left about the gas multiplier, this is ok.


def git_ismaster():
# User can override git_isold checking for a week
if ((float(os.getenv("ICO_DEPLOY_ANYWAY", 0)) + 604800) > time.time()):
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As @ztane mentioned, you don't have to use that many parentheses in Python if, here it's perfectly fine to do this:

if float(os.getenv("ICO_DEPLOY_ANYWAY", 0)) + 604800 > time.time():

And if it's me, I would probably move float(os.getenv("ICO_DEPLOY_ANYWAY", 0)) + 604800 to a separate variable before this condition just to make it a little bit easier to understand, something like this:

deploy_anyway = os.getenv("ICO_DEPLOY_ANYWAY", 0)  # actually I don't know what this value, should it contain which type?
one_week = 60 * 60 * 24 * 7
now = time.time()

if deploy_anyway + one_week > now:

Btw why is this time check done in this function and not in git_isold()? It doesn't seem to relate to the current function that much.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants