tests, fixes, client can read when connected
This commit is contained in:
parent
25f65334cd
commit
3665fe0eac
@ -8,6 +8,12 @@ authors:
|
|||||||
description: |
|
description: |
|
||||||
High-level Crystal bindings to libipc.
|
High-level Crystal bindings to libipc.
|
||||||
|
|
||||||
|
targets:
|
||||||
|
pongd:
|
||||||
|
main: tests/pongd.cr
|
||||||
|
pongc:
|
||||||
|
main: tests/pongc.cr
|
||||||
|
|
||||||
libraries:
|
libraries:
|
||||||
libipc: ">= 0.7"
|
libipc: ">= 0.7"
|
||||||
|
|
||||||
|
@ -2,6 +2,20 @@
|
|||||||
class IPC::Client < IPC::Context
|
class IPC::Client < IPC::Context
|
||||||
property server_fd : Int32?
|
property server_fd : Int32?
|
||||||
|
|
||||||
|
def read
|
||||||
|
unless (fd = @server_fd).nil?
|
||||||
|
message = LibIPC::Message.new
|
||||||
|
r = LibIPC.ipc_read_fd(fd, pointerof(message))
|
||||||
|
if r.error_code != 0
|
||||||
|
m = String.new r.error_message.to_slice
|
||||||
|
raise Exception.new "error reading a message: #{m}"
|
||||||
|
end
|
||||||
|
IPC::Message.new pointerof(message)
|
||||||
|
else
|
||||||
|
raise "Client not connected to a server"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
# By default, this is a client.
|
# By default, this is a client.
|
||||||
def initialize(service_name : String)
|
def initialize(service_name : String)
|
||||||
super()
|
super()
|
||||||
|
@ -110,8 +110,8 @@ class IPC::Context
|
|||||||
send(fd, utype, Bytes.new(payload.to_unsafe, payload.bytesize))
|
send(fd, utype, Bytes.new(payload.to_unsafe, payload.bytesize))
|
||||||
end
|
end
|
||||||
|
|
||||||
def send(fd : Int32, message : IPC::Message)
|
def send(message : IPC::Message)
|
||||||
send(fd, message.fd, message.utype, message.payload)
|
send(message.fd, message.utype, message.payload)
|
||||||
end
|
end
|
||||||
|
|
||||||
def read(index : UInt32)
|
def read(index : UInt32)
|
||||||
|
5
tests/colors.cr
Normal file
5
tests/colors.cr
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
CRED = "\033[31m"
|
||||||
|
CBLUE = "\033[36m"
|
||||||
|
CGREEN = "\033[32m"
|
||||||
|
CRESET = "\033[00m"
|
||||||
|
CORANGE = "\033[33m"
|
3
tests/pong.c
Normal file
3
tests/pong.c
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
require "../src/ipc.cr"
|
||||||
|
|
||||||
|
IPC::Client.new "pong"
|
23
tests/pongc.cr
Normal file
23
tests/pongc.cr
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
require "../src/ipc.cr"
|
||||||
|
|
||||||
|
client = IPC::Client.new "pong"
|
||||||
|
|
||||||
|
server_fd = client.server_fd
|
||||||
|
|
||||||
|
if server_fd.nil?
|
||||||
|
exit 1
|
||||||
|
end
|
||||||
|
|
||||||
|
message = IPC::Message.new server_fd, 1, 42.to_u8, "salut ça va ?"
|
||||||
|
|
||||||
|
client.send message
|
||||||
|
|
||||||
|
client.loop do |event|
|
||||||
|
case event
|
||||||
|
when IPC::Event::MessageReceived
|
||||||
|
puts "\033[32mthere is a message\033[00m"
|
||||||
|
puts event.message.to_s
|
||||||
|
client.close
|
||||||
|
exit
|
||||||
|
end
|
||||||
|
end
|
78
tests/pongd.cr
Normal file
78
tests/pongd.cr
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
require "option_parser"
|
||||||
|
require "../src/ipc.cr"
|
||||||
|
require "./colors"
|
||||||
|
|
||||||
|
verbosity = 1
|
||||||
|
service_name = "pong"
|
||||||
|
no_response = false
|
||||||
|
|
||||||
|
OptionParser.parse do |parser|
|
||||||
|
parser.on "-s service_name", "--service-name service_name", "URI" do |optsn|
|
||||||
|
service_name = optsn
|
||||||
|
end
|
||||||
|
|
||||||
|
parser.on "-n", "--no-response", "Do not provide any response back." do
|
||||||
|
no_response = true
|
||||||
|
end
|
||||||
|
|
||||||
|
parser.on "-v verbosity", "--verbosity verbosity", "Verbosity (0 = nothing is printed, 1 = only events, 2 = events and messages). Default: 1" do |optsn|
|
||||||
|
verbosity = optsn.to_i
|
||||||
|
end
|
||||||
|
|
||||||
|
parser.on "-h", "--help", "Show this help" do
|
||||||
|
puts parser
|
||||||
|
exit 0
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
service = IPC::Server.new (service_name)
|
||||||
|
service.base_timer = 5000 # 5 seconds
|
||||||
|
service.timer = 5000 # 5 seconds
|
||||||
|
|
||||||
|
service.loop do |event|
|
||||||
|
case event
|
||||||
|
when IPC::Event::Timer
|
||||||
|
if verbosity >= 1
|
||||||
|
puts "#{CORANGE}IPC::Event::Timer#{CRESET}"
|
||||||
|
end
|
||||||
|
when IPC::Event::Connection
|
||||||
|
if verbosity >= 1
|
||||||
|
puts "#{CBLUE}IPC::Event::Connection#{CRESET}, client: #{event.fd}"
|
||||||
|
end
|
||||||
|
when IPC::Event::Disconnection
|
||||||
|
if verbosity >= 1
|
||||||
|
puts "#{CBLUE}IPC::Event::Disconnection#{CRESET}, client: #{event.fd}"
|
||||||
|
end
|
||||||
|
when IPC::Event::MessageSent
|
||||||
|
begin
|
||||||
|
if verbosity >= 1
|
||||||
|
puts "#{CGREEN}IPC::Event::MessageSent#{CRESET}, client: #{event.fd}"
|
||||||
|
end
|
||||||
|
rescue e
|
||||||
|
puts "#{CRED}#{e.message}#{CRESET}"
|
||||||
|
service.remove_fd event.fd
|
||||||
|
end
|
||||||
|
when IPC::Event::MessageReceived
|
||||||
|
begin
|
||||||
|
if verbosity >= 1
|
||||||
|
puts "#{CGREEN}IPC::Event::MessageReceived#{CRESET}, client: #{event.fd}"
|
||||||
|
if verbosity >= 2
|
||||||
|
m = String.new event.message.payload
|
||||||
|
puts "#{CBLUE}message type #{event.message.utype}: #{m} #{CRESET}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
service.send event.message unless no_response
|
||||||
|
if verbosity >= 2 && ! no_response
|
||||||
|
puts "#{CBLUE}sending message...#{CRESET}"
|
||||||
|
end
|
||||||
|
|
||||||
|
rescue e
|
||||||
|
puts "#{CRED}#{e.message}#{CRESET}"
|
||||||
|
service.remove_fd event.fd
|
||||||
|
end
|
||||||
|
else
|
||||||
|
if verbosity >= 1
|
||||||
|
puts "#{CRED}Exception: message #{event} #{CRESET}"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Reference in New Issue
Block a user