mirror of
https://github.com/we-promise/sure.git
synced 2026-04-08 14:54:49 +00:00
* Add support for dynamic config UI
* Add support for section description
* Better dynamic class settings
Added dynamic_fields hash field - Stores all undeclared settings
[] method - Checks declared fields first, then falls back to dynamic hash
[]= method - Updates declared fields normally, stores others in hash
No runtime field declaration - Fields are never dynamically created on the class
* FIX proper lookup for provider keys
- Also validate configurable values properly.
- Change Provider factory to use Rails autoloading (Zeitwerk)
* Fix factory
The derive_adapter_name method relies on string manipulation ("PlaidAccount".sub(/Account$/, "") + "Adapter" → "PlaidAdapter"), but we already have explicit registration in place.
* Make updates atomic, field-aware, and handle blanks explicitly
* Small UX detail
* Add support for PlaidEU in UI also
- This looks like partial support atm
68 lines
2.2 KiB
Ruby
68 lines
2.2 KiB
Ruby
require "test_helper"
|
|
|
|
class Provider::RegistryTest < ActiveSupport::TestCase
|
|
test "providers filters out nil values when provider is not configured" do
|
|
# Ensure OpenAI is not configured
|
|
ClimateControl.modify("OPENAI_ACCESS_TOKEN" => nil) do
|
|
Setting.stubs(:openai_access_token).returns(nil)
|
|
|
|
registry = Provider::Registry.for_concept(:llm)
|
|
|
|
# Should return empty array instead of [nil]
|
|
assert_equal [], registry.providers
|
|
end
|
|
end
|
|
|
|
test "providers returns configured providers" do
|
|
# Mock a configured OpenAI provider
|
|
mock_provider = mock("openai_provider")
|
|
Provider::Registry.stubs(:openai).returns(mock_provider)
|
|
|
|
registry = Provider::Registry.for_concept(:llm)
|
|
|
|
assert_equal [ mock_provider ], registry.providers
|
|
end
|
|
|
|
test "get_provider raises error when provider not found for concept" do
|
|
registry = Provider::Registry.for_concept(:llm)
|
|
|
|
error = assert_raises(Provider::Registry::Error) do
|
|
registry.get_provider(:nonexistent)
|
|
end
|
|
|
|
assert_match(/Provider 'nonexistent' not found for concept: llm/, error.message)
|
|
end
|
|
|
|
test "get_provider returns nil when provider not configured" do
|
|
# Ensure OpenAI is not configured
|
|
ClimateControl.modify("OPENAI_ACCESS_TOKEN" => nil) do
|
|
Setting.stubs(:openai_access_token).returns(nil)
|
|
|
|
registry = Provider::Registry.for_concept(:llm)
|
|
|
|
# Should return nil when provider method exists but returns nil
|
|
assert_nil registry.get_provider(:openai)
|
|
end
|
|
end
|
|
|
|
test "openai provider falls back to Setting when ENV is empty string" do
|
|
# Mock ENV to return empty string (common in Docker/env files)
|
|
# Use stub_env helper which properly stubs ENV access
|
|
ClimateControl.modify(
|
|
"OPENAI_ACCESS_TOKEN" => "",
|
|
"OPENAI_URI_BASE" => "",
|
|
"OPENAI_MODEL" => ""
|
|
) do
|
|
Setting.stubs(:openai_access_token).returns("test-token-from-setting")
|
|
Setting.stubs(:openai_uri_base).returns(nil)
|
|
Setting.stubs(:openai_model).returns(nil)
|
|
|
|
provider = Provider::Registry.get_provider(:openai)
|
|
|
|
# Should successfully create provider using Setting value
|
|
assert_not_nil provider
|
|
assert_instance_of Provider::Openai, provider
|
|
end
|
|
end
|
|
end
|