I am working on the "Advantage database server" adapter extension, to try and talk to a legacy database that I have access to (that is still in active usage).
I have updated the "Advantage" Gem so that it works on new/active versions of Ruby https://github.com/t12nslookup/advantage and have seen that my copy of the activerecord-advantage-adapter https://github.com/t12nslookup/activerecord_advantage_adapter works on ruby 1.9.3 and rails 3.2.22
I have been working to try to force it to work with rails 6, and have had reasonable success with a simple "ruby" script that "require"s the gems and accesses the data, but I cannot get the same simple database query to work at the rails console.
I'm running in WSL 2, if it makes any difference (but I don't believe it.
ruby 2.7.0p0 (2019-12-25 revision 647ee6f091) [x86_64-linux], Rails 6.0.3.3
I have added a rails6 branch to the activerecord-advantage-adapter github project.
Ruby script:
jadams@Temp046317:~/code/ais-lims$ more ../testme.rb
require 'rubygems'
gem 'advantage'
gem "activerecord-advantage-adapter"
require "active_record"
ActiveRecord::Base.establish_connection(
adapter: 'advantage',
options: 'ServerType=Local|Remote; ReadOnly=True; CommType=TCP_IP; Compression=INTERNET',
database: '//172.27.176.1:6262/c$/ads/db/'
)
class Discount < ActiveRecord::Base
self.table_name = 'DISCOUNT'
self.sequence_name = :autogenerated
end
puts Discount.all.inspect
puts Discount.count
jadams@Temp046317:~/code/ais-lims$ ruby ../testme.rb
#<ActiveRecord::Relation [#<Discount >, #<Discount >, #<Discount >, #<Discount >]>
4
Rails console:
jadams@Temp046317:~/code/ais-lims$ more config/database.yml
development:
adapter: 'advantage'
options: 'ServerType=Local|Remote; ReadOnly=True; CommType=TCP_IP; Compression=INTERNET'
database: '//172.27.176.1:6262/c$/ads/db/'
jadams@Temp046317:~/code/ais-lims$ more app/models/discount.rb
class Discount < ApplicationRecord
self.table_name = 'DISCOUNT'
self.sequence_name = :autogenerated
end
jadams@Temp046317:~/code/ais-lims$ rails c
Running via Spring preloader in process 728
Loading development environment (Rails 6.0.3.3)
2.7.0 :001 > puts Discount.all.inspect
Traceback (most recent call last):
1: from (irb):1
NoMethodError (undefined method `to_sym' for nil:NilClass)
2.7.0 :002 > puts Discount.count
Traceback (most recent call last):
2: from (irb):1
1: from (irb):2:in `rescue in irb_binding'
NoMethodError (undefined method `to_sym' for nil:NilClass)
Any hints on how to debug, or where to find the issue, I'd be grateful.
Jon
@rmlockerd and @ruby_object were both correct in helping to debug, but at the end of the day I'd just written the section of code in a way that didn't work.
debugging was key