From 987d767a33b0f8a71e6ad32fbbc6aa7c8b9ef095 Mon Sep 17 00:00:00 2001 From: Matthias Fey Date: Wed, 15 Nov 2023 11:42:17 +0100 Subject: [PATCH] Fix for new `pyg_lib.neighbor_sample` argument order (#8381) --- .github/workflows/full_gpu_testing.yml | 1 + .github/workflows/full_testing.yml | 1 + .github/workflows/latest_testing.yml | 1 + .github/workflows/minimal_testing.yml | 1 + .github/workflows/prev_testing.yml | 1 + .github/workflows/testing.yml | 1 + test/loader/test_neighbor_loader.py | 6 +++--- test/test_config_store.py | 1 - torch_geometric/distributed/dist_neighbor_sampler.py | 1 + torch_geometric/sampler/neighbor_sampler.py | 8 ++++++-- torch_geometric/typing.py | 2 ++ 11 files changed, 18 insertions(+), 6 deletions(-) diff --git a/.github/workflows/full_gpu_testing.yml b/.github/workflows/full_gpu_testing.yml index 83996c800b68..6be1a15f7712 100644 --- a/.github/workflows/full_gpu_testing.yml +++ b/.github/workflows/full_gpu_testing.yml @@ -29,6 +29,7 @@ jobs: pip install -e .[full,test] - name: Run tests + timeout-minutes: 20 run: | FULL_TEST=1 pytest shell: bash diff --git a/.github/workflows/full_testing.yml b/.github/workflows/full_testing.yml index a9dde191dd4b..f178f467d6eb 100644 --- a/.github/workflows/full_testing.yml +++ b/.github/workflows/full_testing.yml @@ -50,6 +50,7 @@ jobs: pip install -e .[full,test] - name: Run tests + timeout-minutes: 20 run: | FULL_TEST=1 pytest --cov --cov-report=xml shell: bash diff --git a/.github/workflows/latest_testing.yml b/.github/workflows/latest_testing.yml index b90e91e00511..91d97256ce57 100644 --- a/.github/workflows/latest_testing.yml +++ b/.github/workflows/latest_testing.yml @@ -45,5 +45,6 @@ jobs: - name: Run tests if: steps.changed-files-specific.outputs.only_changed != 'true' + timeout-minutes: 10 run: | pytest diff --git a/.github/workflows/minimal_testing.yml b/.github/workflows/minimal_testing.yml index ee6c57dda8b1..d2a419959ad1 100644 --- a/.github/workflows/minimal_testing.yml +++ b/.github/workflows/minimal_testing.yml @@ -45,5 +45,6 @@ jobs: - name: Run tests if: steps.changed-files-specific.outputs.only_changed != 'true' + timeout-minutes: 10 run: | pytest diff --git a/.github/workflows/prev_testing.yml b/.github/workflows/prev_testing.yml index 5769ffd5a062..115acb510a5c 100644 --- a/.github/workflows/prev_testing.yml +++ b/.github/workflows/prev_testing.yml @@ -58,5 +58,6 @@ jobs: - name: Run tests if: steps.changed-files-specific.outputs.only_changed != 'true' + timeout-minutes: 10 run: | pytest diff --git a/.github/workflows/testing.yml b/.github/workflows/testing.yml index b334b3376f24..58fffd9341cd 100644 --- a/.github/workflows/testing.yml +++ b/.github/workflows/testing.yml @@ -43,6 +43,7 @@ jobs: - name: Run tests if: steps.changed-files-specific.outputs.only_changed != 'true' + timeout-minutes: 10 run: | pytest --cov --cov-report=xml --durations 10 diff --git a/test/loader/test_neighbor_loader.py b/test/loader/test_neighbor_loader.py index 6a31e3e5e585..11bb42c6c125 100644 --- a/test/loader/test_neighbor_loader.py +++ b/test/loader/test_neighbor_loader.py @@ -530,7 +530,7 @@ def test_pyg_lib_and_torch_sparse_homo_equality(): seed = torch.arange(10) sample = torch.ops.pyg.neighbor_sample - out1 = sample(colptr, row, seed, [-1, -1], None, None, None, True) + out1 = sample(colptr, row, seed, [-1, -1], None, None, None, None, True) sample = torch.ops.torch_sparse.neighbor_sample out2 = sample(colptr, row, seed, [-1, -1], False, True) @@ -570,8 +570,8 @@ def test_pyg_lib_and_torch_sparse_hetero_equality(): sample = torch.ops.pyg.hetero_neighbor_sample out1 = sample(node_types, edge_types, colptr_dict, row_dict, seed_dict, - num_neighbors_dict, None, None, None, True, False, True, - False, "uniform", True) + num_neighbors_dict, None, None, None, None, True, False, + True, False, "uniform", True) sample = torch.ops.torch_sparse.hetero_neighbor_sample out2 = sample(node_types, edge_types, colptr_dict, row_dict, seed_dict, num_neighbors_dict, 2, False, True) diff --git a/test/test_config_store.py b/test/test_config_store.py index 71820766732a..cb753a0b2fd3 100644 --- a/test/test_config_store.py +++ b/test/test_config_store.py @@ -145,4 +145,3 @@ def test_hydra_config_store(): assert cfg.lr_scheduler.cooldown == 0 assert cfg.lr_scheduler.min_lr == 0 assert cfg.lr_scheduler.eps == 1e-08 - assert not cfg.lr_scheduler.verbose diff --git a/torch_geometric/distributed/dist_neighbor_sampler.py b/torch_geometric/distributed/dist_neighbor_sampler.py index 9c0748432693..7c02df48f54f 100644 --- a/torch_geometric/distributed/dist_neighbor_sampler.py +++ b/torch_geometric/distributed/dist_neighbor_sampler.py @@ -625,6 +625,7 @@ def _sample_one_hop( input_nodes.to(colptr.dtype), num_neighbors, node_time, + None, # edge_time seed_time, None, # TODO: edge_weight True, # csc diff --git a/torch_geometric/sampler/neighbor_sampler.py b/torch_geometric/sampler/neighbor_sampler.py index 758b76469f7e..099479ca9992 100644 --- a/torch_geometric/sampler/neighbor_sampler.py +++ b/torch_geometric/sampler/neighbor_sampler.py @@ -300,8 +300,10 @@ def _sample( seed, self.num_neighbors.get_mapped_values(self.edge_types), self.node_time, - seed_time, ) + if torch_geometric.typing.WITH_EDGE_TIME_NEIGHBOR_SAMPLE: + args += (None, ) + args += (seed_time, ) if torch_geometric.typing.WITH_WEIGHTED_NEIGHBOR_SAMPLE: args += (self.edge_weight, ) args += ( @@ -380,8 +382,10 @@ def _sample( seed.to(self.colptr.dtype), self.num_neighbors.get_mapped_values(), self.node_time, - seed_time, ) + if torch_geometric.typing.WITH_EDGE_TIME_NEIGHBOR_SAMPLE: + args += (None, ) + args += (seed_time, ) if torch_geometric.typing.WITH_WEIGHTED_NEIGHBOR_SAMPLE: args += (self.edge_weight, ) args += ( diff --git a/torch_geometric/typing.py b/torch_geometric/typing.py index a5cd7a27b3dc..d9e687601178 100644 --- a/torch_geometric/typing.py +++ b/torch_geometric/typing.py @@ -42,6 +42,8 @@ WITH_SAMPLED_OP = hasattr(pyg_lib.ops, 'sampled_add') WITH_INDEX_SORT = hasattr(pyg_lib.ops, 'index_sort') WITH_METIS = hasattr(pyg_lib, 'partition') + WITH_EDGE_TIME_NEIGHBOR_SAMPLE = ('edge_time' in inspect.signature( + pyg_lib.sampler.neighbor_sample).parameters) WITH_WEIGHTED_NEIGHBOR_SAMPLE = ('edge_weight' in inspect.signature( pyg_lib.sampler.neighbor_sample).parameters) except Exception as e: