-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
Command Migration: ('PFADD', 'PFCOUNT', 'PFMERGE') #1032
Comments
@AshwinKul28, @lucifercr07 @JyotinderSingh I would love to work on this. Please assign this to me |
Thanks @surya0180 go for it 🚀 |
HI @surya0180 , I hope you are doing well. Do you happen to have any updates on this? If you've any doubts please let us know on the discord. |
Hi @AshwinKul28. I am still exploring the codebase to better understand how things get triggered through different protocols. Working on Go language after a long time, its taking sometime for me to understand few things, but its actually done now. I am going to send a PR by EOD or at max by tomorrow morning!. Thanks! |
@AshwinKul28, There is a method in eval_test called runEvalTests, which runs the tests for the given eval function. Initially, this function was written for RESP only. However, since we are now supporting multiple protocols, we need to add a new function that does the same but accepts an eval function with a return type of EvalResponse. Based on what you shared in this issue, you referenced a PR that includes the migration of GET, SET, GETSET, etc., but I am unable to find the new method required to execute these new eval functions. Could you please advise if we need to write the logic for this function inside our eval functions, or is there a reusable function we can use? |
Hi @surya0180 thanks for the update. Based on the sample PR, you need to migrate the current Eval function to the new one by moving it to the store_eval.go file and making required changes which returns *EvalResponse in return. You may need to make changes in the respective unit test functions. |
This issue tracks the migration of the mentioned commands - ('PFADD', 'PFCOUNT', 'PFMERGE') to make them compatible across the three protocols supported by the Dice database: RESP, HTTP, and WebSocket.
DiceDB now supports more than one protocols (Resp/http/websocket). We don't want eval operation of each command to be strictly bound with any of the protocols. Currently eval function return statements of each command is bounded to the RESP protocol.
The migration is required because:
The goal is to make the command logic protocol-independent, allowing all three protocols to call the same core functionality seamlessly.
Requirements
[Command Name]
to be generic.Migration Steps
Analyze Current Implementation
Refactor Return Logic
evalXXX(args []string, store *dstore.Store) *EvalResponse
under the file/internal/eval/store_eval.go
/errors/migrated_errors.go
file/internal/clientio/resp.go
file as RespType variablesCommand/Worker specific Changes
IsMigrated
flag to true in the commands information under/internal/eval/commands.go
file.NewEval
parameter in the same command structure./internal/eval/eval.go
file./internal/worker/CommandsMeta
map and make it's type asSingleShard
Update Unit Tests
Integration Tests
Checklist
Additional Notes
If there are any questions or concerns about this migration, please mention them here.
Related Issues/PRs
The text was updated successfully, but these errors were encountered: