using GenericLinearAlgebra, GenericSchur

@testset "linear algebra" begin
    @test issquare(reshape(rand(Double32,3*3), 3, 3))

    # issue #77
    if VERSION < v"1.1"
      M = Double64.([1 0; 1 1])
      @test_throws AssertionError exp(M)
      M = Complex{Double64}.([1 0; 1 1])
      @test_throws AssertionError exp(M)
    else
      M = Double64.([1 0; 1 1])
      @test_throws ErrorException exp(M)
      M = Complex{Double64}.([1 0; 1 1])
      @test_throws ErrorException exp(M)
    end        
        
    t=[Complex{Double64}(1.0,0.0) Complex{Double64}(0.0,1.0);
       Complex{Double64}(0.0,-1.0) Complex{Double64}(1.0,0.0)]
    @test ishermitian(t)

    @test norm(Complex{Double64}[2, 2im]) ≈ norm(ComplexF64[2, 2im])
    @test norm(Complex{Double64}[2, 2im]) isa Double64

    @test norm(Complex{Double64}[2, 2im], 3.0) ≈ norm(ComplexF64[2, 2im], 3.0)
    @test norm(Complex{Double64}[2, 2im], 3.0) isa Double64

    @test norm(Double64[2, 1]) ≈ norm(Float64[2, 1])
    @test norm(Double64[2, 1], 3.0) ≈ norm(Float64[2, 1], 3.0)

    # issue #105
    for T in [Double16, Double32, Double64]
        for p in [0, 1.0, 2.0, Inf, -Inf]
            @test norm(T[], p) == zero(T)
            @test norm(Complex{T}[], p) == zero(T)

            @test normalize(T[]) == T[]
            @test normalize(Complex{T}[]) == Complex{T}[]
        end
    end
end
