rpl.rb/spec/language_trig_spec.rb

73 lines
1.9 KiB
Ruby
Raw Normal View History

2022-01-18 17:07:25 +01:00
# coding: utf-8
# frozen_string_literal: true
require 'test/unit'
require_relative '../language'
class TesttLanguageOperations < Test::Unit::TestCase
def test_pi
lang = Rpl::Language.new
lang.run 'pi'
2022-02-08 15:45:36 +01:00
assert_equal [{ value: BigMath.PI( Rpl::Lang.precision ), type: :numeric, base: 10 }],
2022-01-18 17:07:25 +01:00
lang.stack
end
def test_sin
lang = Rpl::Language.new
lang.run '3 sin'
2022-02-08 15:45:36 +01:00
assert_equal [{ value: BigMath.sin( BigDecimal( 3 ), Rpl::Lang.precision ), type: :numeric, base: 10 }],
2022-01-18 17:07:25 +01:00
lang.stack
end
def test_asin
lang = Rpl::Language.new
lang.run '1 asin pi 2 / =='
assert_equal [{ value: true, type: :boolean }],
2022-01-18 17:07:25 +01:00
lang.stack
end
def test_cos
lang = Rpl::Language.new
lang.run '3 cos'
2022-02-08 15:45:36 +01:00
assert_equal [{ value: BigMath.cos( BigDecimal( 3 ), Rpl::Lang.precision ), type: :numeric, base: 10 }],
2022-01-18 17:07:25 +01:00
lang.stack
end
def test_acos
lang = Rpl::Language.new
lang.run '0 acos pi 2 / =='
assert_equal [{ value: true, type: :boolean }],
2022-01-18 17:07:25 +01:00
lang.stack
end
def test_tan
lang = Rpl::Language.new
lang.run '0 tan 0 =='
assert_equal [{ value: true, type: :boolean }],
2022-01-18 17:07:25 +01:00
lang.stack
end
def test_atan
lang = Rpl::Language.new
lang.run '1 atan'
2022-02-08 15:45:36 +01:00
assert_equal [{ value: BigMath.atan( BigDecimal( 1 ), Rpl::Lang.precision ), type: :numeric, base: 10 }],
2022-01-18 17:07:25 +01:00
lang.stack
end
def test_dr
lang = Rpl::Language.new
2022-02-02 16:42:19 +01:00
lang.run '90 d→r'
2022-02-08 15:45:36 +01:00
assert_equal [{ value: BigDecimal( 1.57079632679489661923132169168272243847381663981000003, Rpl::Lang.precision ),
2022-02-02 16:42:19 +01:00
type: :numeric, base: 10 }],
2022-01-18 17:07:25 +01:00
lang.stack
end
def test_rd
lang = Rpl::Language.new
lang.run 'pi r→d'
assert_equal [{ value: 180, type: :numeric, base: 10 }],
2022-01-18 17:07:25 +01:00
lang.stack
end
end