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

Audit and make documentation for command DECR consistent #111

Open
arpitbbhayani opened this issue Sep 28, 2024 · 9 comments
Open

Audit and make documentation for command DECR consistent #111

arpitbbhayani opened this issue Sep 28, 2024 · 9 comments
Assignees
Labels
documentation Improvements or additions to documentation good first issue Good for newcomers

Comments

@arpitbbhayani
Copy link
Contributor

The documentation of the command [DECR](https://dicedb.io/commands/decr/) present in this directory could have become stale. We need your help to ensure that the documentation is complete, correct, and consistent.  Completing this issue will give you much-needed exposure to how the command is implemented and the different parameters it accepts. Hence, this is a great way to build a good understanding of the project and its functionality. While still making a significant contribution. Here's what you need to do:

  1. Go through the documentation of the command and run all the examples, making sure they all work as expected
  2. If the same command is present in Redis, then the expected output of the DiceDB command is the same as the Redis output
  3. If the command is not in Redis, then as per your judgment, raise an issue with this template or fix the documentation and raise a pull request in the docs repository.
  4. The documentation should contain the following sections in the following order
  • short and concise introduction paragraph about the command covering what it does
  • Syntax
  • Parameters: List all the parameters the command accepts, and ignore the section if there are no parameters
  • Return values: List all possible return values and under what condition
  • Behaviour: Describe the behavior of the command, what it does, how it does it, some internal specifics if any
  • Errors: List all possible errors the command can throw and under what condition
  • Examples: List all possible examples of the command and the expected output. Assume CLI implementation

Note: The title of the sections should be the exact strings mentioned above, like "Examples", "Return values", etc.
Note: The description of the command in Frontmatter of the command.md file is the first paragraph (introduction) of the command.

Go through the DiceDB/dice repository and explore the command implementation

  • to understand all possible return values
  • to understand all possible error values and conditions
  • to understand different parameters the command accepts

Please use the documentation of the SET command as the reference point and structure the
documentation of this command in a very similar way, including the following points

  • if you see any "Conclusion" section, remove it
  • the headers (h1, h2, h3) should be appropriately used
  • the CLI prompt should be 127.0.0.1:7379> and not anything else
  • Use markdown tables for parameters and return values (ref SET command documentation)
  • wrap any command or paramter in backticks (`) to highlight them
  • the section header should be capitalize as used in the SET command documentation

If you find any inconsistencies, please fix the documentation in the DiceDB/docs repository and raise the PR.
The core idea of this exercise is to ensure that the documentation is consistent, correct, and complete.

Note: The PR for changes in documentation needs to be raised in the docs repository while issue or fix in core database implementation will be raised in the dice repository.

Make sure you comment on the other issues you created (if any) as a comment on this issue and also any PR (if any) that you created.
Thank you for picking this up and contributing to the DiceDB. It means a ton.

@arpitbbhayani arpitbbhayani added documentation Improvements or additions to documentation good first issue Good for newcomers labels Sep 28, 2024
@mghildiy
Copy link

Assign this to me.

@arpitbbhayani
Copy link
Contributor Author

@mghildiy go for it. thanks.

@mghildiy
Copy link

mghildiy commented Sep 28, 2024

For non-number value, error message is:

ERROR WRONGTYPE Operation against a key holding the wrong kind of value.

For out of range scenarios, dice returns error message:

ERROR WRONGTYPE Operation against a key holding the wrong kind of value

Redis instead shows(as per documentation):

(error) value is not an integer or out of range

@mghildiy
Copy link

Issue created.

@mghildiy
Copy link

I have a query here.
Should testing be done against latest docker image OR master branch locally? There are differences between their behaviour.

@arpitbbhayani
Copy link
Contributor Author

@mghildiy One slight change.

We have moved docs to the main Dice repository which can be found under the docs directory. The folder structure is the same and you can apply the same changes to the main repository.

Please comment on the same issue on the main Dice repository and raise the PR again. Once again, I'm sorry for the inconvenience.

We have taken this call to keep the doc and the code together allowing us to keep docs consistent with the code and everything to be part of one PR checklist.

Thanks for understanding.

@mghildiy
Copy link

I have a query here. Should testing be done against latest docker image OR master branch locally? There are differences between their behaviour.

@arpitbbhayani , can you provide your opinion on this?

@arpitbbhayani
Copy link
Contributor Author

@mghildiy master branch is better.

@mghildiy
Copy link

PR created.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation Improvements or additions to documentation good first issue Good for newcomers
Projects
None yet
Development

No branches or pull requests

2 participants