"app/vscode:/vscode.git/clone" did not exist on "8b57e715a763b6234053d5b33ddd98db82bc7ae0"
test_basics.py 1.97 KB
Newer Older
1
2
# NOTE(vibwu): Currently cugraph must be imported before torch to avoid a resource cleanup issue.
#    See https://github.com/rapidsai/cugraph/issues/2718
3
4
import unittest

5
import backend as F
6
import cugraph
7
8
import numpy as np
import pytest
9

10
11
12
import dgl
from dgl import DGLGraph

13
14
15
16

def test_dummy():
    cg = cugraph.Graph()
    assert cg is not None
17

18

19
def test_to_cugraph_conversion():
20
    g = dgl.graph((F.tensor([0, 1, 2, 3]), F.tensor([1, 0, 3, 2]))).to("cuda")
21
22
    cugraph_g = g.to_cugraph()

23
24
    assert cugraph_g.number_of_nodes() == g.number_of_nodes()
    assert cugraph_g.number_of_edges() == g.number_of_edges()
25
26
27
28
29

    assert cugraph_g.has_edge(0, 1)
    assert cugraph_g.has_edge(1, 0)
    assert cugraph_g.has_edge(3, 2)

30

31
32
33
34
35
36
def test_from_cugraph_conversion():
    # cudf is a dependency of cugraph
    import cudf

    # directed graph conversion test
    cugraph_g = cugraph.Graph(directed=True)
37
    df = cudf.DataFrame({"source": [0, 1, 2, 3], "destination": [1, 2, 3, 2]})
38
39
40
41
42

    cugraph_g.from_cudf_edgelist(df)

    g = dgl.from_cugraph(cugraph_g)

43
    assert g.device.type == "cuda"
44
45
46
47
48
49
50
51
52
53
54
55
    assert g.number_of_nodes() == cugraph_g.number_of_nodes()
    assert g.number_of_edges() == cugraph_g.number_of_edges()

    # assert reverse edges are not present
    assert g.has_edges_between(0, 1)
    assert not g.has_edges_between(1, 0)
    assert g.has_edges_between(1, 2)
    assert not g.has_edges_between(2, 1)
    assert g.has_edges_between(2, 3)

    # undirected graph conversion test
    cugraph_g = cugraph.Graph(directed=False)
56
    df = cudf.DataFrame({"source": [0, 1, 2, 3], "destination": [1, 2, 3, 2]})
57
58
59
60
61

    cugraph_g.from_cudf_edgelist(df)

    g = dgl.from_cugraph(cugraph_g)

62
    assert g.device.type == "cuda"
63
64
65
66
67
68
69
    assert g.number_of_nodes() == cugraph_g.number_of_nodes()
    # assert reverse edges are present
    assert g.has_edges_between(0, 1)
    assert g.has_edges_between(1, 0)
    assert g.has_edges_between(1, 2)
    assert g.has_edges_between(2, 1)
    assert g.has_edges_between(2, 3)