starlark 0.14.0

An implementation of the Starlark language in Rust.
Documentation
/*
 * Copyright 2019 The Starlark in Rust Authors.
 * Copyright (c) Facebook, Inc. and its affiliates.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

//! Type-related operations.

use crate::assert::Assert;
use crate::typing::tests::TypeCheck;
use crate::typing::tests::register_typecheck_globals;

#[test]
fn test_type_alias() {
    TypeCheck::new().ty("x").check(
        "type_alias",
        r#"
MyList = list[int]

def f(x: MyList):
    pass
"#,
    );
}

#[test]
fn test_incorrect_type_dot() {
    TypeCheck::new().check(
        "incorrect_type_dot",
        r#"
def foo(x: list.foo.bar):
    pass
"#,
    );
}

#[test]
fn test_function_as_type_bit_or() {
    TypeCheck::new().ty("t").check(
        "function_as_type_bit_or",
        r#"
def test():
    # This test should work even if `t` is global. There's a bug in test framework somewhere.
    t = int | str
"#,
    );
}

#[test]
fn test_function_as_type_parameterize() {
    let a = Assert::new();
    a.fail(
        r#"
def f(x: str[int]):
    pass
"#,
        "not supported",
    );
}

#[test]
fn test_starlark_value_as_type_unsupported_param() {
    let mut a = Assert::new();
    a.globals_add(register_typecheck_globals);
    a.fail(
        r#"
def f(x: MyCustomType[int]):
    pass
"#,
        "does not support type parameters",
    );
}

#[test]
fn test_list_parametrize() {
    let a = Assert::new();
    a.pass(
        r#"
def f(x: list[str]) -> list[str]:
    return x
"#,
    );
}

#[test]
fn test_set_parametrize() {
    let a = Assert::new();
    a.pass(
        r#"
def f(x: set[int]) -> set[int]:
    return x
"#,
    );
}

#[test]
fn test_list_too_many_type_params() {
    let a = Assert::new();
    a.fail(
        r#"
def f(x: list[str, int]):
    pass
"#,
        "[,] can only be applied to dict or tuple functions in type expression",
    );
}