mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-25 00:07:47 +01:00
Fix(export API): accept true
and false
as param values (#2349)
## What This PR updates the `paramToBool` function to first check whether the incoming argument is a boolean. This fixes the bug where using `true` or `false` (e.g. `Strategies=false`) in the query would cause the server to crash. I've also added a test case to check for these values. ## Why While working on the import/export API docs, I noticed that using `false` in an export request caused the server to crash. As we want to allow `true` and `false` (and use these values in the documentation), we should ensure that they work as expected. ## Background It's likely that this bug was introduced when we added the new OpenAPI query parameters to the export endpoint. Because of the way that the OpenAPI service we use does conversion, we now get `true` and `false` converted to actual boolean values instead of strings. The `paramToBool` function didn't account for that previously, which is why it caused the server to crash.
This commit is contained in:
parent
75c3fcd170
commit
d5e33ab1f2
@ -23,6 +23,10 @@ import { OpenAPIV3 } from 'openapi-types';
|
||||
|
||||
const upload = multer({ limits: { fileSize: 5242880 } });
|
||||
const paramToBool = (param, def) => {
|
||||
if (typeof param === 'boolean') {
|
||||
return param;
|
||||
}
|
||||
|
||||
if (param === null || param === undefined) {
|
||||
return def;
|
||||
}
|
||||
|
@ -55,6 +55,12 @@ test('exports strategies and features as attachment', async () => {
|
||||
.expect(200);
|
||||
});
|
||||
|
||||
test('accepts "true" and "false" as parameter values', () => {
|
||||
return app.request
|
||||
.get('/api/admin/state/export?strategies=true&tags=false')
|
||||
.expect(200);
|
||||
});
|
||||
|
||||
test('imports strategies and features', async () => {
|
||||
return app.request
|
||||
.post('/api/admin/state/import')
|
||||
|
Loading…
Reference in New Issue
Block a user