Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

500 server error in development env when the serial port doesn't exist on server #48

Open
JakeTheSnake3p0 opened this issue Feb 5, 2014 · 1 comment

Comments

@JakeTheSnake3p0
Copy link

Normally I use SerialPort on a server which has a virtual COM port set up to communicate over the LAN with another computer's point of sale display pole. This is set up as COM3 on the server. Everything works as expected...in production mode only. Having scoured the web for the error that was popping up, I came across a solution where I have to set config.cache_classes = true in development mode. Here's a sample of the code I'm using; keep in mind that regardless of whether or not I have a begin/rescue block, WEBrick still servers a 500 server error. I have to exit the controller method prematurely and return head :no_content before anything happens with SerialPort if I want to avoid this problem in development mode:

POST method - Ajax request from browser app has header X-Message which gets written to COM port (and thus sent back to display pole)
def update_display_pole
    begin
        SerialPort.open(Rails.configuration.serial_port,
                Rails.configuration.serial_port_baud_rate,
                Rails.configuration.serial_port_bits,
                Rails.configuration.serial_port_parity, 
                Rails.configuration.serial_port_flow) do |s|

            s.write request.headers['X-Message']

        end
        head :no_content
    rescue
        head :internal_server_error, 'X-Reason'=> "Cannot communicate with COM port"
    end
end

Now in production mode if the COM port doesn't exist, the begin/rescue block works as expected. However in development mode I don't get any errors other than "500 server error" in my logs.

@hparra
Copy link
Owner

hparra commented Feb 17, 2014

I'm also stumped. It's been a long times since I've worked with rails. Could it be some be some threading issue? See config.threadsafe!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants