diff --git a/CHANGELOG.md b/CHANGELOG.md index 3894f3d..229c255 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ # Changelog +## [0.6.0+1] - 08/03/2020 + +* improved documentation and refactored tests + ## [0.6.0] - 08/02/2020 * doIfExists: do something if exists a key and return something diff --git a/README.md b/README.md index e6f785f..cdaeb6d 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,6 @@ -# Overview [![Pub](https://img.shields.io/pub/v/ms_map_utils.svg)](https://pub.dartlang.org/packages/ms_map_utils) ![GitHub stars](https://img.shields.io/github/stars/Marcus-Software/ms_map_utils?style=social) +# Overview [![Pub](https://img.shields.io/pub/v/ms_map_utils.svg)](https://pub.dartlang.org/packages/ms_map_utils) + +![GitHub stars](https://img.shields.io/github/stars/Marcus-Software/ms_map_utils?style=social) A simple lib to incremease Map with usefull functions @@ -6,45 +8,204 @@ A simple lib to incremease Map with usefull functions Add usefull functions to map: -- `trim` trim all Strings in a map _it's recursive_ -- `compact` remove all MapEntries thats values is `null` _it's recursive too_ -- `reduce` iterate all items in `Map` for reduce to a unique value returned from callback `ReduceFunction`. -- `removeKeys` remove all entries that contains a key in list. -- `removeKeysExcept` remove all entries that NOT contains a key in list. -- `putIfAbsentAsync` put a item if absent or return existent value async. -- `containsKeys` check if map contains all keys of list. -- `doIfContains` do some work if map contains a key. +* `trim` trim all Strings in a map _it's recursive_. +* `compact` remove all MapEntries thats values is `null` _it's recursive too_. +* `reduce` iterate all items in `Map` for reduce to a unique value returned from callback `ReduceFunction` . +* `removeKeys` remove all entries that contains a key in list. +* `removeKeysExcept` remove all entries that NOT contains a key in list. +* `putIfAbsentAsync` put a item if absent or return existent value async. +* `containsKeys` check if map contains all keys of list. +* `doIfContains` do some work if map contains a key. ## Usage Just import lib and use [extensions](https://dart.dev/guides/language/extension-methods), call the functions to starts work: -```dart +``` dart +// Don't forget to import import 'package:ms_map_utils/ms_map_utils.dart'; -Map itsAMap = {'key1':null,'key2':' just a String withs extras spaces en start and end '}; -itsAMap.compact(); // Output: {'key2':' just a String withs extras spaces en start and end '} -itsAMap.trim(); // Output: {'key2':'just a String withs extras spaces en start and end'} - -Map mapNumbers = {'key1':50,'key2':7,'key3':71,'key4':45,'key5':5}; -// In reduceFunction you must check if `accumulated` is null and set a initial value for it -mapNumbers.reduce((int accumulated, _, value) => (accumulated ?? 0) + (value as int)); // Output 178 -mapNumbers.removeKeys(['key1','key5']); //{'key2':7,'key3':71,'key4':45} -mapNumbers.removeKeysExcept(['key3']); //{'key3':71} -var item = await anyMap.putIfAbsentAsync('randomKey', () async { - await Future.delayed(Duration(milliseconds: 1500)); - return 'Random Value'; +Map itsAMap = {'key1' : null, 'key2' : 'just a String'}; +compact(itsAMap); // Output: {'key2':'just a String'} +// or using extensions. +itsAMap.compact(); // Output: {'key2':'just a String'} +``` + +## trim + +The function `trim` all Strings in a map _it's recursive_. + +``` dart + test('Most trim any Strings values', () { + const mapToTrim = { + 'key1': ' random string ', + 'key2': ' another random string ', + 'key3': 321 + }; + expect(mapToTrim.trim(true), { + 'key1': 'random string', + 'key2': 'another random string', + 'key3': 321 }); -if (mapNumbers.containsKeys(['key1','key2'])) { - print('The map contians all keys [key1, key2]'); -} + }); +``` + +see more in [test file](./test/trim_test.dart). + +## compact + +The function `compact` remove all MapEntries thats values is `null` _it's recursive_. + +``` dart +test('Must return a new empty HashMap without null values', () { + var mapWithNullValues = { + 'k1': null, + 'k2': null, + 'k3': null, + 'map': { + 'k1': null, + 'k2': null, + 'k3': null, + }, + 'list': [ + { + 'k1': null, + 'k2': null, + 'k3': null, + }, + { + 'k1': null, + 'k2': null, + 'k3': null, + }, + ] + }; + var mapWithoutNull = compact(mapWithNullValues); + expect(mapWithoutNull, { + 'map': {}, + 'list': [{}, {}] + }); + }); +``` + +see more in [test file](./test/compact_test.dart). + +## reduce + +The function `reduce` iterate all items in `Map` for reduce to a unique value returned from callback `ReduceFunction` . + +``` dart + test('Multiplies all int values to 120', () { + Map mapNumbers = { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + }; + var value = mapNumbers + .reduce((int acc, _, value) => (acc ?? 1) * (value as int)); + expect(value, 120, reason: 'Value reduced must be 120'); + }); +``` + +see more in [test file](./test/reduce_test.dart). + +## removeKeys + +The function `removeKeys` remove all entries that contains a key in list. + +``` dart + test('Remove all entries that has a key in list with recursive', () { + Map mapNumbers = { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + 'map': { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + } + }; + mapNumbers.removeKeys(['key1', 'key2'], true); + expect(mapNumbers.length, 4); + expect(mapNumbers['map'].length, 3); + }); ``` -### doIfContains +see more in [test file](./test/remove_keys_test.dart). + +## removeKeysExcept + +The function `removeKeysExcept` remove all entries that NOT contains a key in list. + +``` dart + test('Remove all entries that has a key NOT in list with recursive', () { + Map mapNumbers = { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + 'map': { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + } + }; + mapNumbers.removeKeysExcept(['key1', 'key2', 'map'], true); + expect(mapNumbers.length, 3); + expect(mapNumbers['map'].length, 2); + }); +``` + +see more in [test file](./test/remove_keys_except_test.dart). + +## putIfAbsentAsync + +The function `putIfAbsentAsync` put a item if absent or return existent value async. + +``` dart + test('Call async function for empty map', () async { + var emptyMap = {}; + expect(emptyMap.containsKey('test'), isFalse); + var item = await emptyMap.putIfAbsentAsync('test', () async { + await Future.delayed(Duration(milliseconds: 1500)); + return 'Random String'; + }); + expect(emptyMap, isNotEmpty); + expect(emptyMap.containsKey('test'), isTrue); + expect(item, 'Random String'); + }); +``` + +see more in [test file](./test/put_if_absent_async_test.dart). + +## containsKeys + +The function `containsKeys` check if map contains all keys of list. + +``` dart + test('Must return true if contains a list of keys', () { + var listOfKeyToCheck = ['key1', 'key2']; + var mapToCheck = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'}; + expect(mapToCheck.containsKeys(listOfKeyToCheck), isTrue); + }); +``` + +see more in [test file](./test/contains_keys_test.dart). + +## doIfContains The function `doIfContains` will be call a callback function if the map contains a key ou else it will be a callback function `elseIf` if `elseIf` is null, null will returned. -```dart +``` dart test('must return a object if contains a key', () { final testMap = {'key1': 'value1', 'key2': 'value2'}; final newThing = doIfContains>(testMap, 'key2', diff --git a/example/main.dart b/example/main.dart index 03cfad4..e3c098d 100644 --- a/example/main.dart +++ b/example/main.dart @@ -7,7 +7,7 @@ Future main(List args) async { // Trim all strings values print({'key1': ' Imagine random string here '}.trim()); - Map justMap = { + var justMap = { 'key1': null, 'key2': ' just a String withs extras spaces en start and end ' @@ -21,7 +21,7 @@ Future main(List args) async { // {key2: just a String withs extras spaces en start and end} print(justMap.trim()); - Map mapNumbers = {'key1': 50, 'key2': 7, 'key3': 71, 'key4': 45, 'key5': 5}; + var mapNumbers = {'key1': 50, 'key2': 7, 'key3': 71, 'key4': 45, 'key5': 5}; // In reduceFunction you must check is acc is null and set a initial value for it var sumValues = mapNumbers.reduce((int accumulated, _, value) => (accumulated ?? 0) + (value as int)); // Output 178 diff --git a/lib/functions/do_if_contains.dart b/lib/functions/do_if_contains.dart index 8ec66c8..333d182 100644 --- a/lib/functions/do_if_contains.dart +++ b/lib/functions/do_if_contains.dart @@ -3,7 +3,7 @@ part of '../ms_map_utils.dart'; /// Return a result of [doWork] if a map contains a key or return /// a result of [elseIf] if non null else will return null T doIfContains(Map map, Object key, - {T Function(Object key, Object value) doWork, T Function() elseIf}) { + {@required T Function(Object key, Object value) doWork, T Function() elseIf}) { assert(doWork != null, 'doWork should not be non null'); assert(map != null, 'map should not be non null'); if (map?.containsKey(key) == true) { diff --git a/lib/ms_map_utils.dart b/lib/ms_map_utils.dart index 09fbb0f..41274b1 100644 --- a/lib/ms_map_utils.dart +++ b/lib/ms_map_utils.dart @@ -1,3 +1,5 @@ +import 'package:meta/meta.dart'; + part './functions/compact.dart'; part './functions/contains_keys.dart'; part './functions/put_if_absent_async.dart'; diff --git a/pubspec.yaml b/pubspec.yaml index 8fa101c..e952b1f 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -1,6 +1,6 @@ name: ms_map_utils description: A dart package that implement a lot of util functions for a Map -version: 0.6.0 +version: 0.6.0+1 homepage: https://github.com/Marcus-Software/ms_map_utils environment: diff --git a/test/compact_test.dart b/test/compact_test.dart new file mode 100644 index 0000000..486047e --- /dev/null +++ b/test/compact_test.dart @@ -0,0 +1,56 @@ +import 'package:ms_map_utils/ms_map_utils.dart'; +import 'package:test/test.dart'; + +void main() { + test('Must return a new empty HashMap without null values', () { + var mapWithNullValues = { + 'k1': null, + 'k2': null, + 'k3': null, + 'map': { + 'k1': null, + 'k2': null, + 'k3': null, + }, + 'list': [ + { + 'k1': null, + 'k2': null, + 'k3': null, + }, + { + 'k1': null, + 'k2': null, + 'k3': null, + }, + ] + }; + var mapWithoutNull = compact(mapWithNullValues); + expect(mapWithoutNull, { + 'map': {}, + 'list': [{}, {}] + }); + }); + test('Must return a new HashMap without null values', () { + var mapWithNullValues = { + 'k1': null, + 'k2': null, + 'k3': null, + 'k4': 'any value' + }; + var mapWithoutNull = compact(mapWithNullValues); + expect(mapWithoutNull.length, 1); + expect(mapWithoutNull, {'k4': 'any value'}); + }); + test('Must return a new HashMap without null values', () { + var mapWithNullValues = { + 'k1': null, + 'k2': null, + 'k3': null, + 'k4': 'any value' + }; + var mapWithoutNull = mapWithNullValues.compact(true); + expect(mapWithoutNull.length, 1); + expect(mapWithoutNull, {'k4': 'any value'}); + }); +} diff --git a/test/contains_keys_test.dart b/test/contains_keys_test.dart new file mode 100644 index 0000000..e5e84c1 --- /dev/null +++ b/test/contains_keys_test.dart @@ -0,0 +1,31 @@ +import 'package:ms_map_utils/ms_map_utils.dart'; +import 'package:test/test.dart'; + +void main() { + test('Must return true if contains a list of keys', () { + var listOfKeyToCheck = ['key1', 'key2']; + var mapToCheck = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'}; + expect(mapToCheck.containsKeys(listOfKeyToCheck), isTrue); + }); + test('Must return false if not contains a key in list', () { + var listOfKeyToCheck = ['key1', 'key4']; + var mapToCheck = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'}; + expect(mapToCheck.containsKeys(listOfKeyToCheck), isFalse); + }); + + test('Must return true if contains only keys in list', () { + var listOfKeyToCheck = ['key1', 'key2']; + var mapToCheck = {'key1': 'value1', 'key2': 'value2'}; + expect( + mapToCheck.containsKeys(listOfKeyToCheck, rule: ContainsKeysRules.only), + isTrue); + }); + + test('Must return false if contains only keys in list', () { + var listOfKeyToCheck = ['key1', 'key2']; + var mapToCheck = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'}; + expect( + mapToCheck.containsKeys(listOfKeyToCheck, rule: ContainsKeysRules.only), + isFalse); + }); +} diff --git a/test/do_if_contains_test.dart b/test/do_if_contains_test.dart index 03ada3c..7a5e10e 100644 --- a/test/do_if_contains_test.dart +++ b/test/do_if_contains_test.dart @@ -32,6 +32,7 @@ void main() { test('must return throw assertion error if doWork is null', () { final testMap = {'key1': 'value1', 'key2': 'value2'}; + // ignore: missing_required_param expect(() => doIfContains>(testMap, 'key3'), throwsA(TypeMatcher())); }); diff --git a/test/ms_map_utils_test.dart b/test/ms_map_utils_test.dart deleted file mode 100644 index 3266037..0000000 --- a/test/ms_map_utils_test.dart +++ /dev/null @@ -1,297 +0,0 @@ -import 'package:ms_map_utils/ms_map_utils.dart'; -import 'package:test/test.dart'; - -void main() { - group('Compact Map', () { - test('Must return a new empty HashMap without null values', () { - var mapWithNullValues = { - 'k1': null, - 'k2': null, - 'k3': null, - 'map': { - 'k1': null, - 'k2': null, - 'k3': null, - }, - 'list': [ - { - 'k1': null, - 'k2': null, - 'k3': null, - }, - { - 'k1': null, - 'k2': null, - 'k3': null, - }, - ] - }; - var mapWithoutNull = compact(mapWithNullValues); - expect(mapWithoutNull, { - 'map': {}, - 'list': [{}, {}] - }); - }); - test('Must return a new HashMap without null values', () { - var mapWithNullValues = { - 'k1': null, - 'k2': null, - 'k3': null, - 'k4': 'any value' - }; - var mapWithoutNull = compact(mapWithNullValues); - expect(mapWithoutNull.length, 1); - expect(mapWithoutNull, {'k4': 'any value'}); - }); - test('Must return a new HashMap without null values', () { - var mapWithNullValues = { - 'k1': null, - 'k2': null, - 'k3': null, - 'k4': 'any value' - }; - var mapWithoutNull = mapWithNullValues.compact(true); - expect(mapWithoutNull.length, 1); - expect(mapWithoutNull, {'k4': 'any value'}); - }); - }); - group('Trim Strings on map', () { - test('Most trim any Strings values', () { - const mapToTrim = { - 'key1': ' random string ', - 'key2': ' another random string ', - 'key3': 321 - }; - expect(mapToTrim.trim(true), { - 'key1': 'random string', - 'key2': 'another random string', - 'key3': 321 - }); - }); - test('Most trim any Strings values and map enhered', () { - const mapToTrim = { - 'key1': ' random string ', - 'key2': ' another random string ', - 'map': { - 'key1': ' random string ', - 'key2': ' another random string ', - 'map': { - 'key1': ' random string ', - 'key2': ' another random string ', - } - } - }; - expect(mapToTrim.trim(true), { - 'key1': 'random string', - 'key2': 'another random string', - 'map': { - 'key1': 'random string', - 'key2': 'another random string', - 'map': { - 'key1': 'random string', - 'key2': 'another random string', - } - } - }); - }); - }); - group('Must trim list with maps', () { - test('Trim a map with a list of maps', () { - var mapToTrim = { - 'key': [ - {'key': ' random string '}, - {'key': ' another random string '}, - {'key': ' last random string '}, - ] - }; - expect(mapToTrim.trim(true), { - 'key': [ - {'key': 'random string'}, - {'key': 'another random string'}, - {'key': 'last random string'}, - ] - }); - }); - }); - - group('Must reduce a map to unique value', () { - test('Sum all int values to 178', () { - Map mapNumbers = { - 'key1': 50, - 'key2': 7, - 'key3': 71, - 'key4': 45, - 'key5': 5, - }; - var value = mapNumbers - .reduce((int acc, _, value) => (acc ?? 0) + (value as int)); - expect(value, 178, reason: 'Value reduced must be 178'); - }); - test('Multiplies all int values to 120', () { - Map mapNumbers = { - 'key1': 1, - 'key2': 2, - 'key3': 3, - 'key4': 4, - 'key5': 5, - }; - var value = mapNumbers - .reduce((int acc, _, value) => (acc ?? 1) * (value as int)); - expect(value, 120, reason: 'Value reduced must be 120'); - }); - test('Concat all keys to "key1key2key3key4key5"', () { - Map mapNumbers = { - 'key1': 1, - 'key2': 2, - 'key3': 3, - 'key4': 4, - 'key5': 5, - }; - var value = mapNumbers - .reduce((String acc, key, _) => (acc ?? '') + key.toString()); - expect(value, 'key1key2key3key4key5', - reason: 'Value reduced must be "key1key2key3key4key5"'); - }); - }); - - group('RemoveKeysExcept', () { - test('Remove all entries that has a key NOT in list', () { - Map mapNumbers = { - 'key1': 1, - 'key2': 2, - 'key3': 3, - 'key4': 4, - 'key5': 5, - 'map': { - 'key1': 1, - 'key2': 2, - 'key3': 3, - 'key4': 4, - 'key5': 5, - } - }; - mapNumbers.removeKeysExcept(['key1', 'key2', 'map']); - expect(mapNumbers.length, 3); - expect(mapNumbers['map'].length, 5); - }); - test('Remove all entries that has a key NOT in list with recursive', () { - Map mapNumbers = { - 'key1': 1, - 'key2': 2, - 'key3': 3, - 'key4': 4, - 'key5': 5, - 'map': { - 'key1': 1, - 'key2': 2, - 'key3': 3, - 'key4': 4, - 'key5': 5, - } - }; - mapNumbers.removeKeysExcept(['key1', 'key2', 'map'], true); - expect(mapNumbers.length, 3); - expect(mapNumbers['map'].length, 2); - }); - }); - - group('RemoveKeys', () { - test('Remove all entries that has a key in list', () { - Map mapNumbers = { - 'key1': 1, - 'key2': 2, - 'key3': 3, - 'key4': 4, - 'key5': 5, - 'map': { - 'key1': 1, - 'key2': 2, - 'key3': 3, - 'key4': 4, - 'key5': 5, - } - }; - mapNumbers.removeKeys(['key1', 'key2']); - expect(mapNumbers.length, 4); - expect(mapNumbers['map'].length, 5); - }); - test('Remove all entries that has a key in list with recursive', () { - Map mapNumbers = { - 'key1': 1, - 'key2': 2, - 'key3': 3, - 'key4': 4, - 'key5': 5, - 'map': { - 'key1': 1, - 'key2': 2, - 'key3': 3, - 'key4': 4, - 'key5': 5, - } - }; - mapNumbers.removeKeys(['key1', 'key2'], true); - expect(mapNumbers.length, 4); - expect(mapNumbers['map'].length, 3); - }); - }); - - group('Put if absent async', () { - test('Call async function for empty map', () async { - var emptyMap = {}; - expect(emptyMap.containsKey('test'), isFalse); - var item = await emptyMap.putIfAbsentAsync('test', () async { - await Future.delayed(Duration(milliseconds: 1500)); - return 'Random String'; - }); - expect(emptyMap, isNotEmpty); - expect(emptyMap.containsKey('test'), isTrue); - expect(item, 'Random String'); - }); - test('Call async function for non empty map', () async { - var emptyMap = {'test': 'Older String'}; - expect(emptyMap.containsKey('test'), isTrue); - var beforeRun = DateTime.now(); - var item = await emptyMap.putIfAbsentAsync('test', () async { - await Future.delayed(Duration(milliseconds: 1500)); - return 'Random String'; - }); - var afterRun = DateTime.now(); - expect(emptyMap.containsKey('test'), isTrue); - expect(item != 'Random String', isTrue); - expect(item == 'Older String', isTrue); - expect(afterRun.difference(beforeRun).inMilliseconds < 1500, isTrue); - }); - }); - - group('Contains a lot of keys', () { - test('Must return true if contains a list of keys', () { - var listOfKeyToCheck = ['key1', 'key2']; - var mapToCheck = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'}; - expect(mapToCheck.containsKeys(listOfKeyToCheck), isTrue); - }); - test('Must return false if not contains a key in list', () { - var listOfKeyToCheck = ['key1', 'key4']; - var mapToCheck = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'}; - expect(mapToCheck.containsKeys(listOfKeyToCheck), isFalse); - }); - - test('Must return true if contains only keys in list', () { - var listOfKeyToCheck = ['key1', 'key2']; - var mapToCheck = {'key1': 'value1', 'key2': 'value2'}; - expect( - mapToCheck.containsKeys(listOfKeyToCheck, - rule: ContainsKeysRules.only), - isTrue); - }); - - test('Must return false if contains only keys in list', () { - var listOfKeyToCheck = ['key1', 'key2']; - var mapToCheck = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'}; - expect( - mapToCheck.containsKeys(listOfKeyToCheck, - rule: ContainsKeysRules.only), - isFalse); - }); - }); -} diff --git a/test/put_if_absent_async_test.dart b/test/put_if_absent_async_test.dart new file mode 100644 index 0000000..9b5724b --- /dev/null +++ b/test/put_if_absent_async_test.dart @@ -0,0 +1,31 @@ +import 'package:ms_map_utils/ms_map_utils.dart'; +import 'package:test/test.dart'; + +void main() { + test('Call async function for empty map', () async { + var emptyMap = {}; + expect(emptyMap.containsKey('test'), isFalse); + var item = await emptyMap.putIfAbsentAsync('test', () async { + await Future.delayed(Duration(milliseconds: 1500)); + return 'Random String'; + }); + expect(emptyMap, isNotEmpty); + expect(emptyMap.containsKey('test'), isTrue); + expect(item, 'Random String'); + }); + + test('Call async function for non empty map', () async { + var emptyMap = {'test': 'Older String'}; + expect(emptyMap.containsKey('test'), isTrue); + var beforeRun = DateTime.now(); + var item = await emptyMap.putIfAbsentAsync('test', () async { + await Future.delayed(Duration(milliseconds: 1500)); + return 'Random String'; + }); + var afterRun = DateTime.now(); + expect(emptyMap.containsKey('test'), isTrue); + expect(item != 'Random String', isTrue); + expect(item == 'Older String', isTrue); + expect(afterRun.difference(beforeRun).inMilliseconds < 1500, isTrue); + }); +} diff --git a/test/reduce_test.dart b/test/reduce_test.dart new file mode 100644 index 0000000..3a0e0f9 --- /dev/null +++ b/test/reduce_test.dart @@ -0,0 +1,45 @@ +import 'package:ms_map_utils/ms_map_utils.dart'; +import 'package:test/test.dart'; + +void main() { + + test('Sum all int values to 178', () { + Map mapNumbers = { + 'key1': 50, + 'key2': 7, + 'key3': 71, + 'key4': 45, + 'key5': 5, + }; + var value = mapNumbers + .reduce((int acc, _, value) => (acc ?? 0) + (value as int)); + expect(value, 178, reason: 'Value reduced must be 178'); + }); + + test('Multiplies all int values to 120', () { + Map mapNumbers = { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + }; + var value = mapNumbers + .reduce((int acc, _, value) => (acc ?? 1) * (value as int)); + expect(value, 120, reason: 'Value reduced must be 120'); + }); + + test('Concat all keys to "key1key2key3key4key5"', () { + Map mapNumbers = { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + }; + var value = mapNumbers + .reduce((String acc, key, _) => (acc ?? '') + key.toString()); + expect(value, 'key1key2key3key4key5', + reason: 'Value reduced must be "key1key2key3key4key5"'); + }); +} diff --git a/test/remove_keys_except_test.dart b/test/remove_keys_except_test.dart new file mode 100644 index 0000000..22088bb --- /dev/null +++ b/test/remove_keys_except_test.dart @@ -0,0 +1,45 @@ +import 'package:ms_map_utils/ms_map_utils.dart'; +import 'package:test/test.dart'; + +void main() { + test('Remove all entries that has a key NOT in list', () { + // ignore: omit_local_variable_types + Map mapNumbers = { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + 'map': { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + } + }; + mapNumbers.removeKeysExcept(['key1', 'key2', 'map']); + expect(mapNumbers.length, 3); + expect(mapNumbers['map'].length, 5); + }); + test('Remove all entries that has a key NOT in list with recursive', () { + // ignore: omit_local_variable_types + Map mapNumbers = { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + 'map': { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + } + }; + mapNumbers.removeKeysExcept(['key1', 'key2', 'map'], true); + expect(mapNumbers.length, 3); + expect(mapNumbers['map'].length, 2); + }); +} diff --git a/test/remove_keys_test.dart b/test/remove_keys_test.dart new file mode 100644 index 0000000..7f52a67 --- /dev/null +++ b/test/remove_keys_test.dart @@ -0,0 +1,45 @@ +import 'package:ms_map_utils/ms_map_utils.dart'; +import 'package:test/test.dart'; + +void main() { + test('Remove all entries that has a key in list', () { + // ignore: omit_local_variable_types + Map mapNumbers = { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + 'map': { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + } + }; + mapNumbers.removeKeys(['key1', 'key2']); + expect(mapNumbers.length, 4); + expect(mapNumbers['map'].length, 5); + }); + test('Remove all entries that has a key in list with recursive', () { + // ignore: omit_local_variable_types + Map mapNumbers = { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + 'map': { + 'key1': 1, + 'key2': 2, + 'key3': 3, + 'key4': 4, + 'key5': 5, + } + }; + mapNumbers.removeKeys(['key1', 'key2'], true); + expect(mapNumbers.length, 4); + expect(mapNumbers['map'].length, 3); + }); +} diff --git a/test/trim_test.dart b/test/trim_test.dart new file mode 100644 index 0000000..0c15cbf --- /dev/null +++ b/test/trim_test.dart @@ -0,0 +1,61 @@ +import 'package:ms_map_utils/ms_map_utils.dart'; +import 'package:test/test.dart'; + +void main() { + test('Most trim any Strings values', () { + const mapToTrim = { + 'key1': ' random string ', + 'key2': ' another random string ', + 'key3': 321 + }; + expect(mapToTrim.trim(true), { + 'key1': 'random string', + 'key2': 'another random string', + 'key3': 321 + }); + }); + + test('Most trim any Strings values and map enhered', () { + const mapToTrim = { + 'key1': ' random string ', + 'key2': ' another random string ', + 'map': { + 'key1': ' random string ', + 'key2': ' another random string ', + 'map': { + 'key1': ' random string ', + 'key2': ' another random string ', + } + } + }; + expect(mapToTrim.trim(true), { + 'key1': 'random string', + 'key2': 'another random string', + 'map': { + 'key1': 'random string', + 'key2': 'another random string', + 'map': { + 'key1': 'random string', + 'key2': 'another random string', + } + } + }); + }); + + test('Trim a map with a list of maps', () { + var mapToTrim = { + 'key': [ + {'key': ' random string '}, + {'key': ' another random string '}, + {'key': ' last random string '}, + ] + }; + expect(mapToTrim.trim(true), { + 'key': [ + {'key': 'random string'}, + {'key': 'another random string'}, + {'key': 'last random string'}, + ] + }); + }); +}