Skip to content

Commit

Permalink
Merge branch 'main' into cli-help
Browse files Browse the repository at this point in the history
  • Loading branch information
oeggert authored Jan 16, 2024
2 parents c306525 + 6c49584 commit 837bdc4
Show file tree
Hide file tree
Showing 8 changed files with 179 additions and 173 deletions.
13 changes: 6 additions & 7 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ env:
jobs:
test:
name: Test
runs-on: ubuntu-latest
runs-on: [self-hosted, heavy]
timeout-minutes: 10
strategy:
matrix:
Expand All @@ -34,18 +34,17 @@ jobs:
path: /home/runner/.local
key: dotlocal-${{ matrix.python-version }}-${{ env.POETRY_VERSION }}

- name: Install Python + Retrieve Poetry dependencies from cache
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}

- name: Install poetry
if: steps.cache-poetry.outputs.cache-hit != 'true'
run: |
curl -sSL https://install.python-poetry.org/ | python - --version ${{ env.POETRY_VERSION }}
echo "$HOME/.local/bin" >> $GITHUB_PATH
- name: Install Python + Retrieve Poetry dependencies from cache
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
cache: "poetry"

- name: Display Python version
run: |
python -c "import sys; print(sys.version)"
Expand Down
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Fixed

- Throw an error if a transaction fails instead of continuing
- Support door accounts with multiple bridges

### Changed

Expand Down
283 changes: 138 additions & 145 deletions poetry.lock

Large diffs are not rendered by default.

6 changes: 3 additions & 3 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ xbridge-cli = 'xbridge_cli.main:main'
python = "^3.7.1"
click = "^8.1.3"
tabulate = ">=0.8.9,<0.10.0"
httpx = ">=0.18.1,<0.24.0"
httpx = ">=0.18.1,<0.25.0"
websockets = "^10.3"
Jinja2 = "^3.1.2"
psutil = "^5.9.2"
Expand All @@ -45,8 +45,8 @@ flake8-annotations = "^2.5.0"
flake8-absolute-import = "^1.0"
darglint = "^1.5.8"
types-tabulate = "^0.9.0"
coverage = "^7.0.3"
pytest = "^7.2.0"
coverage = "^7.2.7"
pytest = "^7.4.4"

[tool.isort]
# Make sure that isort's settings line up with black
Expand Down
2 changes: 0 additions & 2 deletions tests/bridge/test_register.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,6 @@ def test_register(self):
send_wallet.seed,
"--to",
wallet_to_create.classic_address,
"--verbose",
],
)
assert runner_result.exit_code == 0, runner_result.output
Expand Down Expand Up @@ -155,7 +154,6 @@ def test_register_bootstrap(self):
send_wallet.seed,
"--to",
wallet_to_create.classic_address,
"--verbose",
],
)
assert runner_result.exit_code == 0, runner_result.output
Expand Down
16 changes: 8 additions & 8 deletions xbridge_cli/bridge/build.py
Original file line number Diff line number Diff line change
Expand Up @@ -338,10 +338,10 @@ def setup_bridge(
raise XBridgeCLIException(obj_error)
locking_door_objs = locking_objs_result["account_objects"]
if len(locking_door_objs) > 0:
assert (
len(locking_door_objs) == 1
), "Cannot have multiple bridges on one account"
if XChainBridge.from_xrpl(locking_door_objs[0]["XChainBridge"]) == bridge_obj:
if any(
XChainBridge.from_xrpl(obj["XChainBridge"]) == bridge_obj
for obj in locking_door_objs
):
locking_bridge_exists = True
else:
raise XBridgeCLIException(
Expand Down Expand Up @@ -457,10 +457,10 @@ def setup_bridge(
raise XBridgeCLIException(obj_error)
issuing_door_objs = issuing_objs_result["account_objects"]
if len(issuing_door_objs) > 0:
assert (
len(issuing_door_objs) == 1
), "Cannot have multiple bridges on one account"
if XChainBridge.from_xrpl(issuing_door_objs[0]["XChainBridge"]) == bridge_obj:
if any(
XChainBridge.from_xrpl(obj["XChainBridge"]) == bridge_obj
for obj in issuing_door_objs
):
issuing_bridge_exists = True
else:
raise XBridgeCLIException(
Expand Down
29 changes: 22 additions & 7 deletions xbridge_cli/bridge/register.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,11 +19,15 @@ def _get_account_objects(
return cast(List[Dict[str, Any]], object_result.result["account_objects"])


# TODO: add support for door accounts that have multiple bridges
def _get_bridge(client: JsonRpcClient, door_account: str) -> Dict[str, Any]:
# TODO: filter by bridge when that's implemented
objects = _get_account_objects(client, door_account)
bridge_objects = [obj for obj in objects if obj["LedgerEntryType"] == "Bridge"]
def _get_bridge(
client: JsonRpcClient, door_account: str, currency: str
) -> Dict[str, Any]:
objects = _get_account_objects(client, door_account, AccountObjectType.BRIDGE)
bridge_objects = [
obj
for obj in objects
if obj["XChainBridge"]["LockingChainIssue"]["currency"] == currency
]
assert len(bridge_objects) == 1
return bridge_objects[0]

Expand Down Expand Up @@ -86,6 +90,14 @@ def _get_bootstrap_chain_and_door(chain_json: Dict[str, Any]) -> Tuple[str, str]
"issuing_chain_door`."
),
)
@click.option(
"--currency",
type=str,
default="XRP",
help=(
"The currency that is being transferred across the bridge. The default is XRP."
),
)
@click.option(
"-v",
"--verbose",
Expand All @@ -97,6 +109,7 @@ def register_bridge(
chains: Optional[Tuple[str, str]],
doors: Optional[Tuple[str, str]],
bootstrap: Optional[str],
currency: str = "XRP",
verbose: int = 0,
) -> None:
"""
Expand All @@ -107,6 +120,8 @@ def register_bridge(
name: The name of the bridge (only used locally).
chains: The locking chain and issuing chain.
doors: The locking chain door and issuing chain door.
currency: The currency that is being transferred across the bridge. The default
is XRP.
bootstrap: The bootstrap file.
verbose: Whether or not to print more verbose information.
Expand Down Expand Up @@ -153,8 +168,8 @@ def register_bridge(
quorum = signer_list1["SignerQuorum"]

# TODO: determine whether the bridge was set up properly.
bridge1 = _get_bridge(locking_client, doors[0])
bridge2 = _get_bridge(issuing_client, doors[1])
bridge1 = _get_bridge(locking_client, doors[0], currency)
bridge2 = _get_bridge(issuing_client, doors[1], currency)
assert bridge1["XChainBridge"] == bridge2["XChainBridge"]
assert bridge1["XChainAccountCreateCount"] == bridge2["XChainAccountClaimCount"]
assert bridge2["XChainAccountCreateCount"] == bridge1["XChainAccountClaimCount"]
Expand Down
2 changes: 1 addition & 1 deletion xbridge_cli/server/start.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@
)
)

_DOCKER_COMPOSE = ["docker", "compose", "-f", _DOCKER_COMPOSE_FILE]
_DOCKER_COMPOSE = ["docker-compose", "-f", _DOCKER_COMPOSE_FILE]

_START_UP_TIME = 30 # seconds
_WAIT_INCREMENT = 0.5 # seconds
Expand Down

0 comments on commit 837bdc4

Please sign in to comment.