Beispiel #1
0
def test_set_block_color_error():
    """
    誤った座標を指定して交点サークルに置かれたブロックの色を取得した場合、例外が送出されることを確認する。
    """
    with pytest.raises(ValueError):
        coordinate = CrossCirclesCoordinate()
        coordinate.set_block_color((-1,0), Color.BLUE)
Beispiel #2
0
def test_set_block_color():
    """
    交点サークルに置かれたブロックの色を設定すると、データ構造の要素も正しく変わることを確認する。
    """
    coordinate = CrossCirclesCoordinate()
    point = (0,0)
    coordinate.set_block_color(point, Color.RED)
    assert coordinate.color(point) == Color.RED
Beispiel #3
0
def test_goal_node():
    """
    走行体の初期位置とブロックサークルの座標を指定すると、ブロックを設置するための交点サークルの座標が正しく返ることを確認する。
    """
    cross_circles = CrossCirclesCoordinate()
    block_circles = create_block_circles()

    assert (1,2) == cross_circles.goal_node((1,1), block_circles.get(3))
    assert (1,2) == cross_circles.goal_node((1,1), block_circles.get(5))
    assert (2,1) == cross_circles.goal_node((2,1.5), block_circles.get(7))
    assert (1,0) == cross_circles.goal_node((3,0), block_circles.get(1))
Beispiel #4
0
def test_init_cross_circle_corrdinate():
    """
    交点サークルの座標を格納するデータ構造を作成したとき、はじめは配置ブロックの色がすべてNONEになっていることを確認する。
    """
    coordinate = CrossCirclesCoordinate()
    for y in range(3+1):
        for x in range(3+1):
            assert coordinate.cross_circles[x, y] == Color.NONE
def create_rule_book(color, bingo=Bingo.DOUBLE_BINGO, black=6):
    is_left = True
    bonus = 1
    color = color
    block_circle = BlockCirclesCoordinate(is_left, bonus, color, black)
    cross_circle = CrossCirclesCoordinate()

    return RuleBook(block_circle, cross_circle, bingo=bingo)
Beispiel #6
0
def test_move_block_of_cross_circle():
    """
    交点サークルに置かれたブロックを移動させたとき、データ構造の要素がNONEになることを確認する。
    """
    coordinate = CrossCirclesCoordinate()
    point = (0,0)
    coordinate.set_block_color(point, Color.BLUE)
    assert coordinate.color(point) == Color.BLUE

    coordinate.move_block(point)
    assert coordinate.color(point) == Color.NONE
Beispiel #7
0
def test_start_node():
    coordinate = CrossCirclesCoordinate()
    # 現実的にはありえないが、交点サークルのすべてに緑色のブロックを配置する
    for x in range(0, 3+1):
        for y in range(0, 3+1):
            coordinate.set_block_color((x,y), Color.GREEN)
    
    # 走行体の現在地から最も近い交点サークルの座標を返すことを確認する。
    assert ((1,1), 0) == coordinate.start_node((1.5,1), [Color.GREEN])
    assert ((1,1), 0) == coordinate.start_node((1,1), [Color.GREEN])

    # 指定色のブロックが置いてある交点サークルがない場合は、Noneが返ることを確認する。
    assert None == coordinate.start_node((1,1), [Color.RED])

    # 1つだけ青色のブロックを置いて、正しく処理できるか確認する
    coordinate.set_block_color((0,2), Color.BLUE)
    assert ((2,0), 2) == coordinate.start_node((2.5,0), [Color.RED, Color.BLUE, Color.GREEN])
    assert ((0,2), 1) == coordinate.start_node((2.5, 0), [Color.YELLOW, Color.BLUE])
def create_commands(is_left=True, bonus=5, color=3, black=6):
    block_circles = BlockCirclesCoordinate(is_left, bonus, color, black)
    cross_circles = CrossCirclesCoordinate()

    return Commands(block_circles, cross_circles)