(command.CommandList children: [ (command.Simple blame_tok: <set> more_env: [] words: [{<set>} {<-euo>} {<pipefail>}] redirects: [] do_fork: T ) (command.ShAssignment left: <Id.Lit_VarLike 'XVFB_PID='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'XVFB_PID='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'XVFB_PID='> name:XVFB_PID) op: assign_op.Equal rhs: {(DQ )} ) ] redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'RUN_SELENIUM='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'RUN_SELENIUM='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'RUN_SELENIUM='> name:RUN_SELENIUM) op: assign_op.Equal rhs: { (DQ (BracedVarSub left: <Id.Left_DollarBrace '${'> token: <Id.VSub_Name RUN_SELENIUM> var_name: RUN_SELENIUM suffix_op: (suffix_op.Unary op:<Id.VTest_ColonHyphen _> arg_word:{<true>}) right: <Id.Right_DollarBrace '}'> ) ) } ) ] redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'BUNDLE_PATH='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'BUNDLE_PATH='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'BUNDLE_PATH='> name:BUNDLE_PATH) op: assign_op.Equal rhs: {(DQ )} ) ] redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'THIS_DIR='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'THIS_DIR='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'THIS_DIR='> name:THIS_DIR) op: assign_op.Equal rhs: { (CommandSub left_token: <Id.Left_DollarParen '$('> child: (command.Simple blame_tok: <dirname> more_env: [] words: [ {<dirname>} { (DQ (CommandSub left_token: <Id.Left_DollarParen '$('> child: (command.Simple blame_tok: <readlink> more_env: [] words: [ {<readlink>} {<-f>} { (DQ (BracedVarSub left: <Id.Left_DollarBrace '${'> token: <Id.VSub_Name BASH_SOURCE> var_name: BASH_SOURCE bracket_op: (bracket_op.ArrayIndex expr:{<Id.Lit_Digits 0>}) right: <Id.Right_DollarBrace '}'> ) ) } ] redirects: [] do_fork: T ) right: <Id.Eof_RParen _> ) ) } ] redirects: [] do_fork: T ) right: <Id.Eof_RParen _> ) } ) ] redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'METEOR_DEV_BUNDLE='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'METEOR_DEV_BUNDLE='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'METEOR_DEV_BUNDLE='> name:METEOR_DEV_BUNDLE) op: assign_op.Equal rhs: { (CommandSub left_token: <Id.Left_DollarParen '$('> child: (command.Simple blame_tok: <Id.Left_DoubleQuote '"'> more_env: [] words: [{(DQ ($ Id.VSub_DollarName THIS_DIR) <'/../find-meteor-dev-bundle.sh'>)}] redirects: [] do_fork: T ) right: <Id.Eof_RParen _> ) } ) ] redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'NODEJS='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'NODEJS='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'NODEJS='> name:NODEJS) op: assign_op.Equal rhs: {(DQ ($ Id.VSub_DollarName METEOR_DEV_BUNDLE) <'/bin/node'>)} ) ] redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'NPM='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'NPM='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'NPM='> name:NPM) op: assign_op.Equal rhs: {(DQ ($ Id.VSub_DollarName METEOR_DEV_BUNDLE) <'/bin/npm'>)} ) ] redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'SELENIUM_JAR='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'SELENIUM_JAR='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'SELENIUM_JAR='> name:SELENIUM_JAR) op: assign_op.Equal rhs: {(DQ <selenium-server-standalone-2.53.0.jar>)} ) ] redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'SELENIUM_JAR_SHA256='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'SELENIUM_JAR_SHA256='> lhs: (sh_lhs_expr.Name left: <Id.Lit_VarLike 'SELENIUM_JAR_SHA256='> name: SELENIUM_JAR_SHA256 ) op: assign_op.Equal rhs: {(DQ <67b88cbfd3b130de6ff3770948f56cc485fd1abb5b7a769397d9050a59b1e036>)} ) ] redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'SELENIUM_DOWNLOAD_URL='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'SELENIUM_DOWNLOAD_URL='> lhs: (sh_lhs_expr.Name left: <Id.Lit_VarLike 'SELENIUM_DOWNLOAD_URL='> name: SELENIUM_DOWNLOAD_URL ) op: assign_op.Equal rhs: { (DQ <'https://selenium-release.storage.googleapis.com/2.53/'> ($ Id.VSub_DollarName SELENIUM_JAR) ) } ) ] redirects: [] ) (command.ShFunction name_tok: <cleanExit> name: cleanExit body: (BraceGroup left: <Id.Lit_LBrace '{'> children: [ (command.ShAssignment left: <Id.Lit_VarLike 'rc='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'rc='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'rc='> name:rc) op: assign_op.Equal rhs: {($ Id.VSub_Number 1)} ) ] redirects: [] ) (command.If if_kw: <Id.KW_If if> arms: [ (IfArm keyword: <Id.KW_If if> cond: (condition.Shell commands: [ (command.Sentence child: (command.Simple blame_tok: <Id.Lit_LBracket '['> more_env: [] words: [ {<Id.Lit_LBracket '['>} {($ Id.VSub_DollarName rc)} {<-ne>} {<0>} {<Id.Lit_RBracket ']'>} ] redirects: [] do_fork: T ) terminator: <Id.Op_Semi _> ) ] ) then_kw: <Id.KW_Then then> action: [ (command.Simple blame_tok: <echo> more_env: [] words: [{<echo>} {(DQ <'Log output: '>)}] redirects: [] do_fork: T ) (command.Simple blame_tok: <cat> more_env: [] words: [ {<cat>} {(DQ ($ Id.VSub_DollarName SANDSTORM_DIR) <'/var/log/sandstorm.log'>)} ] redirects: [] do_fork: T ) ] spids: [148 161] ) ] else_action: [] fi_kw: <Id.KW_Fi fi> redirects: [] ) (command.Simple blame_tok: <Id.Left_DoubleQuote '"'> more_env: [] words: [{(DQ ($ Id.VSub_DollarName SANDSTORM_DIR) <'/sandstorm'>)} {<stop>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <sleep> more_env: [] words: [{<sleep>} {<1>}] redirects: [] do_fork: T ) (command.If if_kw: <Id.KW_If if> arms: [ (IfArm keyword: <Id.KW_If if> cond: (condition.Shell commands: [ (command.Sentence child: (command.Simple blame_tok: <Id.Lit_LBracket '['> more_env: [] words: [ {<Id.Lit_LBracket '['>} {($ Id.VSub_DollarName rc)} {<-eq>} {<0>} {<Id.Lit_RBracket ']'>} ] redirects: [] do_fork: T ) terminator: <Id.Op_Semi _> ) ] ) then_kw: <Id.KW_Then then> action: [ (command.Simple blame_tok: <rm> more_env: [] words: [{<rm>} {<-rf>} {(DQ ($ Id.VSub_DollarName SANDSTORM_DIR))}] redirects: [] do_fork: T ) ] spids: [197 210] ) ] else_action: [] fi_kw: <Id.KW_Fi fi> redirects: [] ) (command.If if_kw: <Id.KW_If if> arms: [ (IfArm keyword: <Id.KW_If if> cond: (condition.Shell commands: [ (command.Sentence child: (command.Simple blame_tok: <Id.Lit_LBracket '['> more_env: [] words: [ {<Id.Lit_LBracket '['>} {<-n>} {(DQ ($ Id.VSub_DollarName XVFB_PID))} {<Id.Lit_RBracket ']'>} ] redirects: [] do_fork: T ) terminator: <Id.Op_Semi _> ) ] ) then_kw: <Id.KW_Then then> action: [ (command.Simple blame_tok: <kill> more_env: [] words: [ {<kill>} { (CommandSub left_token: <Id.Left_DollarParen '$('> child: (command.Simple blame_tok: <pgrep> more_env: [] words: [{<pgrep>} {<--parent>} {($ Id.VSub_DollarName XVFB_PID)} {<java>}] redirects: [] do_fork: T ) right: <Id.Eof_RParen _> ) } ] redirects: [] do_fork: T ) (command.Simple blame_tok: <wait> more_env: [] words: [{<wait>} {($ Id.VSub_DollarName XVFB_PID)}] redirects: [] do_fork: T ) ] spids: [238 252] ) ] else_action: [] fi_kw: <Id.KW_Fi fi> redirects: [] ) (command.ControlFlow keyword: <Id.ControlFlow_Exit exit> arg_word: {($ Id.VSub_DollarName rc)} ) ] redirects: [] right: <Id.Lit_RBrace '}'> ) ) (command.ShFunction name_tok: <cacheSeleniumJar> name: cacheSeleniumJar body: (BraceGroup left: <Id.Lit_LBrace '{'> children: [ (command.If if_kw: <Id.KW_If if> arms: [ (IfArm keyword: <Id.KW_If if> cond: (condition.Shell commands: [ (command.Sentence child: (command.DBracket left: <Id.KW_DLeftBracket '[['> expr: (bool_expr.LogicalNot child: (bool_expr.Unary op_id: Id.BoolUnary_e child: {<'./'> ($ Id.VSub_DollarName SELENIUM_JAR)} ) ) right: <Id.Lit_DRightBracket ']]'> redirects: [] ) terminator: <Id.Op_Semi _> ) ] ) then_kw: <Id.KW_Then then> action: [ (command.ShAssignment left: <Id.Lit_VarLike 'DOWNLOAD='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'DOWNLOAD='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'DOWNLOAD='> name:DOWNLOAD) op: assign_op.Equal rhs: { (CommandSub left_token: <Id.Left_DollarParen '$('> child: (command.Simple blame_tok: <mktemp> more_env: [] words: [{<mktemp>} {<selenium-download.XXXXXX>}] redirects: [] do_fork: T ) right: <Id.Eof_RParen _> ) } ) ] redirects: [] ) (command.Simple blame_tok: <curl> more_env: [] words: [ {<curl>} {<-o>} {($ Id.VSub_DollarName DOWNLOAD)} {($ Id.VSub_DollarName SELENIUM_DOWNLOAD_URL)} ] redirects: [] do_fork: T ) (command.ShAssignment left: <Id.Lit_VarLike 'DOWNLOAD_SHASUM='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'DOWNLOAD_SHASUM='> lhs: (sh_lhs_expr.Name left: <Id.Lit_VarLike 'DOWNLOAD_SHASUM='> name: DOWNLOAD_SHASUM ) op: assign_op.Equal rhs: { (CommandSub left_token: <Id.Left_DollarParen '$('> child: (command.Pipeline children: [ (command.Simple blame_tok: <sha256sum> more_env: [] words: [{<sha256sum>} {($ Id.VSub_DollarName DOWNLOAD)}] redirects: [] do_fork: T ) (command.Simple blame_tok: <cut> more_env: [] words: [{<cut>} {<-f>} {<1>} {<-d>} {(SQ <' '>)}] redirects: [] do_fork: T ) ] ops: [<Id.Op_Pipe _>] ) right: <Id.Eof_RParen _> ) } ) ] redirects: [] ) (command.If if_kw: <Id.KW_If if> arms: [ (IfArm keyword: <Id.KW_If if> cond: (condition.Shell commands: [ (command.Sentence child: (command.DBracket left: <Id.KW_DLeftBracket '[['> expr: (bool_expr.Binary op_id: Id.BoolBinary_GlobEqual left: {(DQ ($ Id.VSub_DollarName DOWNLOAD_SHASUM))} right: {(DQ ($ Id.VSub_DollarName SELENIUM_JAR_SHA256))} ) right: <Id.Lit_DRightBracket ']]'> redirects: [] ) terminator: <Id.Op_Semi _> ) ] ) then_kw: <Id.KW_Then then> action: [ (command.Simple blame_tok: <mv> more_env: [] words: [ {<mv>} {($ Id.VSub_DollarName DOWNLOAD)} {<'./'> ($ Id.VSub_DollarName SELENIUM_JAR)} ] redirects: [] do_fork: T ) ] spids: [359 377] ) ] else_kw: <Id.KW_Else else> else_action: [ (command.Simple blame_tok: <echo> more_env: [] words: [ {<echo>} { (DQ < 'Selenium jar download didn\'t match expected checksum. Discarding.' > ) } ] redirects: [] do_fork: T ) (command.ControlFlow keyword: <Id.ControlFlow_Exit exit> arg_word: {<1>} ) ] fi_kw: <Id.KW_Fi fi> redirects: [] ) ] spids: [302 317] ) ] else_action: [] fi_kw: <Id.KW_Fi fi> redirects: [] ) ] redirects: [] right: <Id.Lit_RBrace '}'> ) ) (command.ShFunction name_tok: <checkInstalled> name: checkInstalled body: (BraceGroup left: <Id.Lit_LBrace '{'> children: [ (command.If if_kw: <Id.KW_If if> arms: [ (IfArm keyword: <Id.KW_If if> cond: (condition.Shell commands: [ (command.Sentence child: (command.Pipeline negated: <Id.KW_Bang '!'> children: [ (command.Simple blame_tok: <Id.Left_DollarParen '$('> more_env: [] words: [ { (CommandSub left_token: <Id.Left_DollarParen '$('> child: (command.Simple blame_tok: <which> more_env: [] words: [{<which>} {($ Id.VSub_Number 1)}] redirects: [ (Redir op: <Id.Redir_Great '>'> loc: (redir_loc.Fd fd:1) arg: {<'/dev/null'>} ) (Redir op: <Id.Redir_Great '2>'> loc: (redir_loc.Fd fd:2) arg: {<'/dev/null'>} ) ] do_fork: T ) right: <Id.Eof_RParen _> ) } ] redirects: [] do_fork: T ) ] ops: [] ) terminator: <Id.Op_Semi _> ) ] ) then_kw: <Id.KW_Then then> action: [ (command.Simple blame_tok: <echo> more_env: [] words: [ {<echo>} { (DQ <'Couldn\'t find executable \''> ($ Id.VSub_Number 1) <'\' - try installing the '> ($ Id.VSub_Number 2) <' package?'> ) } ] redirects: [] do_fork: T ) (command.ControlFlow keyword: <Id.ControlFlow_Exit exit> arg_word: {<1>} ) ] spids: [418 436] ) ] else_action: [] fi_kw: <Id.KW_Fi fi> redirects: [] ) ] redirects: [] right: <Id.Lit_RBrace '}'> ) ) (command.WhileUntil keyword: <Id.KW_While while> cond: (condition.Shell commands: [ (command.Sentence child: (command.Simple blame_tok: <Id.Lit_LBracket '['> more_env: [] words: [ {<Id.Lit_LBracket '['>} {($ Id.VSub_Pound '#')} {<-gt>} {<0>} {<Id.Lit_RBracket ']'>} ] redirects: [] do_fork: T ) terminator: <Id.Op_Semi _> ) ] ) body: (command.DoGroup left: <Id.KW_Do do> children: [ (command.Case case_kw: <Id.KW_Case case> to_match: (case_arg.Word w:{($ Id.VSub_Number 1)}) arms_start: <Id.KW_In in> arms: [ (CaseArm left: <--no-selenium> pattern: (pat.Words words:[{<--no-selenium>}]) middle: <Id.Right_CasePat _> action: [ (command.ShAssignment left: <Id.Lit_VarLike 'RUN_SELENIUM='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'RUN_SELENIUM='> lhs: (sh_lhs_expr.Name left: <Id.Lit_VarLike 'RUN_SELENIUM='> name: RUN_SELENIUM ) op: assign_op.Equal rhs: {(DQ <false>)} ) ] redirects: [] ) ] right: <Id.Op_DSemi _> ) (CaseArm left: <Id.Lit_Star '*'> pattern: (pat.Words words:[{<Id.Lit_Star '*'>}]) middle: <Id.Right_CasePat _> action: [ (command.If if_kw: <Id.KW_If if> arms: [ (IfArm keyword: <Id.KW_If if> cond: (condition.Shell commands: [ (command.Sentence child: (command.Simple blame_tok: <Id.Lit_LBracket '['> more_env: [] words: [ {<Id.Lit_LBracket '['>} {<-n>} {(DQ ($ Id.VSub_DollarName BUNDLE_PATH))} {<Id.Lit_RBracket ']'>} ] redirects: [] do_fork: T ) terminator: <Id.Op_Semi _> ) ] ) then_kw: <Id.KW_Then then> action: [ (command.Simple blame_tok: <echo> more_env: [] words: [ {<echo>} {(DQ <'Multiple bundle paths specified, please name only one.'>)} ] redirects: [] do_fork: T ) (command.ControlFlow keyword: <Id.ControlFlow_Exit exit> arg_word: {<1>} ) ] spids: [504 517] ) ] else_action: [] fi_kw: <Id.KW_Fi fi> redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'BUNDLE_PATH='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'BUNDLE_PATH='> lhs: (sh_lhs_expr.Name left: <Id.Lit_VarLike 'BUNDLE_PATH='> name: BUNDLE_PATH ) op: assign_op.Equal rhs: { (CommandSub left_token: <Id.Left_DollarParen '$('> child: (command.Simple blame_tok: <readlink> more_env: [] words: [{<readlink>} {<-f>} {(DQ ($ Id.VSub_Number 1))}] redirects: [] do_fork: T ) right: <Id.Eof_RParen _> ) } ) ] redirects: [] ) ] right: <Id.Op_DSemi _> ) ] arms_end: <Id.KW_Esac esac> redirects: [] ) (command.Simple blame_tok: <shift> more_env: [] words: [{<shift>}] redirects: [] do_fork: T ) ] right: <Id.KW_Done done> ) redirects: [] ) (command.If if_kw: <Id.KW_If if> arms: [ (IfArm keyword: <Id.KW_If if> cond: (condition.Shell commands: [ (command.Sentence child: (command.Simple blame_tok: <Id.Lit_LBracket '['> more_env: [] words: [ {<Id.Lit_LBracket '['>} {<-z>} {(DQ ($ Id.VSub_DollarName BUNDLE_PATH))} {<Id.Lit_RBracket ']'>} ] redirects: [] do_fork: T ) terminator: <Id.Op_Semi _> ) ] ) then_kw: <Id.KW_Then then> action: [ (command.Simple blame_tok: <echo> more_env: [] words: [ {<echo>} { (DQ <'No bundle path specified; perhaps you meant to write \''> ($ Id.VSub_Number 0) <' sandstorm-0-fast.tar.xz\'?'> ) } ] redirects: [] do_fork: T ) (command.ControlFlow keyword:<Id.ControlFlow_Exit exit> arg_word:{<1>}) ] spids: [558 572] ) ] else_action: [] fi_kw: <Id.KW_Fi fi> redirects: [] ) (command.Simple blame_tok: <cd> more_env: [] words: [{<cd>} {(DQ ($ Id.VSub_DollarName THIS_DIR))}] redirects: [] do_fork: T ) (command.Simple blame_tok: <checkInstalled> more_env: [] words: [{<checkInstalled>} {<firefox>} {<firefox>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <Id.Left_DoubleQuote '"'> more_env: [] words: [{(DQ ($ Id.VSub_DollarName NPM))} {<install>}] redirects: [] do_fork: T ) (command.If if_kw: <Id.KW_If if> arms: [ (IfArm keyword: <Id.KW_If if> cond: (condition.Shell commands: [ (command.Sentence child: (command.Simple blame_tok: <Id.Lit_LBracket '['> more_env: [] words: [ {<Id.Lit_LBracket '['>} {(DQ ($ Id.VSub_DollarName RUN_SELENIUM))} {<Id.KW_Bang '!'> <Id.Lit_Equals '='>} {(DQ <false>)} {<Id.Lit_RBracket ']'>} ] redirects: [] do_fork: T ) terminator: <Id.Op_Semi _> ) ] ) then_kw: <Id.KW_Then then> action: [ (command.Simple blame_tok: <checkInstalled> more_env: [] words: [{<checkInstalled>} {<java>} {<default-jre-headless>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <checkInstalled> more_env: [] words: [{<checkInstalled>} {<xvfb-run>} {<Xvfb>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <checkInstalled> more_env: [] words: [{<checkInstalled>} {<pgrep>} {<procps>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <cacheSeleniumJar> more_env: [] words: [{<cacheSeleniumJar>}] redirects: [] do_fork: T ) (command.Sentence child: (command.Simple blame_tok: <xvfb-run> more_env: [] words: [ {<xvfb-run>} {<--server-args> <Id.Lit_Equals '='> (DQ <'-screen 0, 1280x1024x24'>)} {<java>} {<-jar>} {<'./'> ($ Id.VSub_DollarName SELENIUM_JAR)} ] redirects: [] do_fork: T ) terminator: <Id.Op_Amp _> ) (command.ShAssignment left: <Id.Lit_VarLike 'XVFB_PID='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'XVFB_PID='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'XVFB_PID='> name:XVFB_PID) op: assign_op.Equal rhs: {($ Id.VSub_Bang '!')} ) ] redirects: [] ) ] spids: [612 631] ) ] else_action: [] fi_kw: <Id.KW_Fi fi> redirects: [] ) (command.Simple blame_tok: <export> more_env: [] words: [ {<export>} {<Id.Lit_VarLike 'SANDSTORM_DIR='> ($ Id.VSub_DollarName THIS_DIR) <'/tmp-sandstorm'>} ] redirects: [] do_fork: T ) (command.Simple blame_tok: <export> more_env: [] words: [ {<export>} {<Id.Lit_VarLike 'OVERRIDE_SANDSTORM_DEFAULT_DIR='> ($ Id.VSub_DollarName SANDSTORM_DIR)} ] redirects: [] do_fork: T ) (command.Simple blame_tok: <export> more_env: [] words: [{<export>} {<Id.Lit_VarLike 'PORT='> <9000>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <export> more_env: [] words: [{<export>} {<Id.Lit_VarLike 'MONGO_PORT='> <9001>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <export> more_env: [] words: [{<export>} {<Id.Lit_VarLike 'SMTP_LISTEN_PORT='> <9002>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <export> more_env: [] words: [{<export>} {<Id.Lit_VarLike 'SMTP_OUTGOING_PORT='> <9003>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <export> more_env: [] words: [{<export>} {<Id.Lit_VarLike 'IP_INTERFACE_TEST_PORT='> <9004>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <export> more_env: [] words: [ {<export>} {<Id.Lit_VarLike 'LAUNCH_URL='> (DQ <'http://local.sandstorm.io:'> ($ Id.VSub_DollarName PORT)) } ] redirects: [] do_fork: T ) (command.Simple blame_tok: <rm> more_env: [] words: [{<rm>} {<-rf>} {(DQ ($ Id.VSub_DollarName SANDSTORM_DIR))}] redirects: [] do_fork: T ) (command.Simple blame_tok: <'../install.sh'> more_env: [] words: [{<'../install.sh'>} {<-d>} {<-u>} {(DQ ($ Id.VSub_DollarName BUNDLE_PATH))}] redirects: [] do_fork: T ) (command.Simple blame_tok: <echo> more_env: [] words: [ {<echo>} { (DQ <'IS_TESTING=true\n'> <'ALLOW_DEMO_ACCOUNTS=true\n'> <'BASE_URL=http://local.sandstorm.io:'> ($ Id.VSub_DollarName PORT) <'\n'> <'WILDCARD_HOST=*.local.sandstorm.io:'> ($ Id.VSub_DollarName PORT) <'\n'> <'PORT='> ($ Id.VSub_DollarName PORT) <'\n'> <'MONGO_PORT='> ($ Id.VSub_DollarName MONGO_PORT) <'\n'> <'SMTP_LISTEN_PORT='> (${ Id.VSub_Name SMTP_LISTEN_PORT) <'\n'> <'MAIL_URL=smtp://127.0.0.1:'> (${ Id.VSub_Name SMTP_OUTGOING_PORT) <'\n'> <'UPDATE_CHANNEL=none\n'> ) } ] redirects: [ (Redir op: <Id.Redir_DGreat '>>'> loc: (redir_loc.Fd fd:1) arg: {(DQ ($ Id.VSub_DollarName SANDSTORM_DIR) <'/sandstorm.conf'>)} ) ] do_fork: T ) (command.Simple blame_tok: <Id.Left_DoubleQuote '"'> more_env: [] words: [{(DQ ($ Id.VSub_DollarName SANDSTORM_DIR) <'/sandstorm'>)} {<start>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <echo> more_env: [] words: [{<echo>} {<-n>} {(DQ <'Waiting for sandstorm to start.'>)}] redirects: [] do_fork: T ) (command.ShAssignment left: <Id.Lit_VarLike 'COUNT='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'COUNT='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'COUNT='> name:COUNT) op: assign_op.Equal rhs: {<0>} ) ] redirects: [] ) (command.Sentence child: (command.WhileUntil keyword: <Id.KW_While while> cond: (condition.Shell commands: [ (command.Sentence child: (command.Pipeline negated: <Id.KW_Bang '!'> children: [ (command.Simple blame_tok: <curl> more_env: [] words: [ {<curl>} {<-s>} {<localhost> <Id.Lit_Colon ':'> ($ Id.VSub_DollarName PORT)} ] redirects: [ (Redir op: <Id.Redir_Great '>'> loc: (redir_loc.Fd fd:1) arg: {<'/dev/null'>} ) ] do_fork: T ) ] ops: [] ) terminator: <Id.Op_Semi _> ) ] ) body: (command.DoGroup left: <Id.KW_Do do> children: [ (command.If if_kw: <Id.KW_If if> arms: [ (IfArm keyword: <Id.KW_If if> cond: (condition.Shell commands: [ (command.Sentence child: (command.Simple blame_tok: <Id.Lit_LBracket '['> more_env: [] words: [ {<Id.Lit_LBracket '['>} {(DQ ($ Id.VSub_DollarName COUNT))} {<-gt>} {<600>} {<Id.Lit_RBracket ']'>} ] redirects: [] do_fork: T ) terminator: <Id.Op_Semi _> ) ] ) then_kw: <Id.KW_Then then> action: [ (command.Simple blame_tok: <echo> more_env: [] words: [{<echo>} {(DQ <'Sandstorm failed to start'>)}] redirects: [] do_fork: T ) (command.Simple blame_tok: <cleanExit> more_env: [] words: [{<cleanExit>} {<1>}] redirects: [] do_fork: T ) ] spids: [828 843] ) ] else_action: [] fi_kw: <Id.KW_Fi fi> redirects: [] ) (command.ShAssignment left: <Id.Lit_VarLike 'COUNT='> pairs: [ (AssignPair left: <Id.Lit_VarLike 'COUNT='> lhs: (sh_lhs_expr.Name left:<Id.Lit_VarLike 'COUNT='> name:COUNT) op: assign_op.Equal rhs: { (word_part.ArithSub left: <Id.Left_DollarDParen '$(('> anode: (arith_expr.Binary op_id: Id.Arith_Plus left: {($ Id.VSub_DollarName COUNT)} right: {<Id.Lit_Digits 1>} ) right: <Id.Right_DollarDParen _> ) } ) ] redirects: [] ) (command.Simple blame_tok: <echo> more_env: [] words: [{<echo>} {<-n>} {<.>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <sleep> more_env: [] words: [{<sleep>} {<.1>}] redirects: [] do_fork: T ) ] right: <Id.KW_Done done> ) redirects: [] ) terminator: <Id.Op_Semi _> ) (command.Simple blame_tok:<echo> more_env:[] words:[{<echo>}] redirects:[] do_fork:T) (command.Simple blame_tok: <set> more_env: [] words: [{<set>} {<Id.Lit_Other '+'> <e>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <export> more_env: [] words: [{<export>} {<Id.Lit_VarLike 'DISABLE_DEMO='> <true>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <Id.Left_DoubleQuote '"'> more_env: [] words: [{(DQ ($ Id.VSub_DollarName NPM))} {<test>}] redirects: [] do_fork: T ) (command.Simple blame_tok: <cleanExit> more_env: [] words: [{<cleanExit>} {($ Id.VSub_QMark '?')}] redirects: [] do_fork: T ) ] )