From c8869d61fb4934f12163e28531ee16e55aad8f85 Mon Sep 17 00:00:00 2001 From: khizmax Date: Sat, 21 Jan 2017 18:16:58 +0300 Subject: [PATCH] Added map/set del3 stress-test Removed redundant map stress-tests --- projects/Win/vc14/cds.sln | 87 +- .../Win/vc14/stress-freelist.vcxproj.filters | 24 - ...nd_int.vcxproj => stress-map-del3.vcxproj} | 28 +- .../vc14/stress-map-delodd.vcxproj.filters | 50 - .../vc14/stress-map-find_int.vcxproj.filters | 56 -- .../stress-map-find_string.vcxproj.filters | 56 -- .../stress-map-insdel-func.vcxproj.filters | 53 - .../Win/vc14/stress-map-insdel-int.vcxproj | 273 ------ .../stress-map-insdel-int.vcxproj.filters | 56 -- ...stress-map-insdel-item-int.vcxproj.filters | 53 - .../stress-map-insdel-string.vcxproj.filters | 56 -- .../stress-map-insdelfind.vcxproj.filters | 56 -- .../stress-map-insfind-int.vcxproj.filters | 56 -- ...nd-int.vcxproj => stress-set-del3.vcxproj} | 39 +- .../vc14/stress-set-delodd.vcxproj.filters | 47 - .../stress-set-insdel_func.vcxproj.filters | 50 - .../stress-set-insdel_string.vcxproj.filters | 53 - .../stress-set-insdelfind.vcxproj.filters | 53 - .../vc14/stress-set-iteration.vcxproj.filters | 38 - test/stress/map/CMakeLists.txt | 11 +- test/stress/map/del3/CMakeLists.txt | 29 + .../map_find_int.cpp => del3/map_del3.cpp} | 84 +- test/stress/map/del3/map_del3.h | 881 +++++++++++++++++ .../map_del3_bronsonavltree.cpp} | 4 +- .../map_del3_cuckoo.cpp} | 4 +- .../map_del3_ellentree.cpp} | 4 +- .../map_del3_feldman_hashmap.cpp} | 16 +- .../map_del3_michael.cpp} | 4 +- .../map_del3_skip.cpp} | 4 +- .../map_del3_split.cpp} | 6 +- test/stress/map/find_int/CMakeLists.txt | 31 - test/stress/map/find_int/map_find_int.h | 244 ----- .../find_int/map_find_int_feldman_hashset.cpp | 38 - .../map/find_int/map_find_int_michael.cpp | 39 - .../stress/map/find_int/map_find_int_skip.cpp | 39 - .../map/find_int/map_find_int_split.cpp | 40 - test/stress/map/find_int/map_find_int_std.cpp | 39 - .../map/find_int/map_find_int_striped.cpp | 38 - test/stress/map/insdel_int/CMakeLists.txt | 31 - test/stress/map/insdel_int/map_insdel_int.cpp | 121 --- test/stress/map/insdel_int/map_insdel_int.h | 261 ----- .../map/insdel_int/map_insdel_int_striped.cpp | 38 - test/stress/map/insfind_int/CMakeLists.txt | 31 - .../map_insfind_bronsonavltree.cpp | 38 - .../map/insfind_int/map_insfind_cuckoo.cpp | 38 - .../map/insfind_int/map_insfind_ellentree.cpp | 38 - .../map_insfind_feldman_hashset.cpp | 38 - test/stress/map/insfind_int/map_insfind_int.h | 210 ---- .../map/insfind_int/map_insfind_michael.cpp | 39 - .../map/insfind_int/map_insfind_skip.cpp | 39 - .../map/insfind_int/map_insfind_split.cpp | 40 - .../map/insfind_int/map_insfind_striped.cpp | 38 - test/stress/set/CMakeLists.txt | 2 + test/stress/set/del3/CMakeLists.txt | 28 + .../map_insfind.cpp => set/del3/set_del3.cpp} | 82 +- test/stress/set/del3/set_del3.h | 921 ++++++++++++++++++ .../del3/set_del3_cuckoo.cpp} | 10 +- test/stress/set/del3/set_del3_ellentree.cpp | 38 + .../del3/set_del3_feldman_hashset.cpp} | 22 +- .../del3/set_del3_michael.cpp} | 11 +- .../del3/set_del3_skip.cpp} | 10 +- .../del3/set_del3_split.cpp} | 12 +- 62 files changed, 2119 insertions(+), 2756 deletions(-) delete mode 100644 projects/Win/vc14/stress-freelist.vcxproj.filters rename projects/Win/vc14/{stress-map-find_int.vcxproj => stress-map-del3.vcxproj} (93%) delete mode 100644 projects/Win/vc14/stress-map-delodd.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-map-find_int.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-map-find_string.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-map-insdel-func.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-map-insdel-int.vcxproj delete mode 100644 projects/Win/vc14/stress-map-insdel-int.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-map-insdel-item-int.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-map-insdel-string.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-map-insdelfind.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-map-insfind-int.vcxproj.filters rename projects/Win/vc14/{stress-map-insfind-int.vcxproj => stress-set-del3.vcxproj} (91%) delete mode 100644 projects/Win/vc14/stress-set-delodd.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-set-insdel_func.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-set-insdel_string.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-set-insdelfind.vcxproj.filters delete mode 100644 projects/Win/vc14/stress-set-iteration.vcxproj.filters create mode 100644 test/stress/map/del3/CMakeLists.txt rename test/stress/map/{find_int/map_find_int.cpp => del3/map_del3.cpp} (62%) create mode 100644 test/stress/map/del3/map_del3.h rename test/stress/map/{insdel_int/map_insdel_int_bronsonavltree.cpp => del3/map_del3_bronsonavltree.cpp} (94%) rename test/stress/map/{insdel_int/map_insdel_int_cuckoo.cpp => del3/map_del3_cuckoo.cpp} (94%) rename test/stress/map/{insdel_int/map_insdel_int_ellentree.cpp => del3/map_del3_ellentree.cpp} (94%) rename test/stress/map/{insdel_int/map_insdel_int_feldman_hashset.cpp => del3/map_del3_feldman_hashmap.cpp} (77%) rename test/stress/map/{insdel_int/map_insdel_int_michael.cpp => del3/map_del3_michael.cpp} (94%) rename test/stress/map/{insdel_int/map_insdel_int_skip.cpp => del3/map_del3_skip.cpp} (94%) rename test/stress/map/{insdel_int/map_insdel_int_split.cpp => del3/map_del3_split.cpp} (89%) delete mode 100644 test/stress/map/find_int/CMakeLists.txt delete mode 100644 test/stress/map/find_int/map_find_int.h delete mode 100644 test/stress/map/find_int/map_find_int_feldman_hashset.cpp delete mode 100644 test/stress/map/find_int/map_find_int_michael.cpp delete mode 100644 test/stress/map/find_int/map_find_int_skip.cpp delete mode 100644 test/stress/map/find_int/map_find_int_split.cpp delete mode 100644 test/stress/map/find_int/map_find_int_std.cpp delete mode 100644 test/stress/map/find_int/map_find_int_striped.cpp delete mode 100644 test/stress/map/insdel_int/CMakeLists.txt delete mode 100644 test/stress/map/insdel_int/map_insdel_int.cpp delete mode 100644 test/stress/map/insdel_int/map_insdel_int.h delete mode 100644 test/stress/map/insdel_int/map_insdel_int_striped.cpp delete mode 100644 test/stress/map/insfind_int/CMakeLists.txt delete mode 100644 test/stress/map/insfind_int/map_insfind_bronsonavltree.cpp delete mode 100644 test/stress/map/insfind_int/map_insfind_cuckoo.cpp delete mode 100644 test/stress/map/insfind_int/map_insfind_ellentree.cpp delete mode 100644 test/stress/map/insfind_int/map_insfind_feldman_hashset.cpp delete mode 100644 test/stress/map/insfind_int/map_insfind_int.h delete mode 100644 test/stress/map/insfind_int/map_insfind_michael.cpp delete mode 100644 test/stress/map/insfind_int/map_insfind_skip.cpp delete mode 100644 test/stress/map/insfind_int/map_insfind_split.cpp delete mode 100644 test/stress/map/insfind_int/map_insfind_striped.cpp create mode 100644 test/stress/set/del3/CMakeLists.txt rename test/stress/{map/insfind_int/map_insfind.cpp => set/del3/set_del3.cpp} (51%) create mode 100644 test/stress/set/del3/set_del3.h rename test/stress/{map/insfind_int/map_insfind_std.cpp => set/del3/set_del3_cuckoo.cpp} (91%) create mode 100644 test/stress/set/del3/set_del3_ellentree.cpp rename test/stress/{map/find_int/map_find_int_ellentree.cpp => set/del3/set_del3_feldman_hashset.cpp} (74%) rename test/stress/{map/find_int/map_find_int_bronsonavltree.cpp => set/del3/set_del3_michael.cpp} (86%) rename test/stress/{map/insdel_int/map_insdel_int_std.cpp => set/del3/set_del3_skip.cpp} (90%) rename test/stress/{map/find_int/map_find_int_cuckoo.cpp => set/del3/set_del3_split.cpp} (85%) diff --git a/projects/Win/vc14/cds.sln b/projects/Win/vc14/cds.sln index d420364f..3266280a 100644 --- a/projects/Win/vc14/cds.sln +++ b/projects/Win/vc14/cds.sln @@ -146,12 +146,6 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-map-delodd", "stress {408FE9BC-44F0-4E6A-89FA-D6F952584239} = {408FE9BC-44F0-4E6A-89FA-D6F952584239} EndProjectSection EndProject -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-map-find_int", "stress-map-find_int.vcxproj", "{3F36B97B-8028-4335-ADDD-20B6B81F87AF}" - ProjectSection(ProjectDependencies) = postProject - {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} = {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} - {408FE9BC-44F0-4E6A-89FA-D6F952584239} = {408FE9BC-44F0-4E6A-89FA-D6F952584239} - EndProjectSection -EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-map-find_string", "stress-map-find_string.vcxproj", "{C127CD80-E8A7-47E4-B7EC-1709D2188982}" ProjectSection(ProjectDependencies) = postProject {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} = {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} @@ -164,12 +158,6 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-map-insdel-func", "s {408FE9BC-44F0-4E6A-89FA-D6F952584239} = {408FE9BC-44F0-4E6A-89FA-D6F952584239} EndProjectSection EndProject -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-map-insdel-int", "stress-map-insdel-int.vcxproj", "{46649F79-2919-4B4C-B243-08C724901F58}" - ProjectSection(ProjectDependencies) = postProject - {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} = {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} - {408FE9BC-44F0-4E6A-89FA-D6F952584239} = {408FE9BC-44F0-4E6A-89FA-D6F952584239} - EndProjectSection -EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-map-insdel-string", "stress-map-insdel-string.vcxproj", "{2D0E651D-058D-4D69-9A44-12149E6CA5BE}" ProjectSection(ProjectDependencies) = postProject {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} = {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} @@ -188,12 +176,6 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-map-insdelfind", "st {408FE9BC-44F0-4E6A-89FA-D6F952584239} = {408FE9BC-44F0-4E6A-89FA-D6F952584239} EndProjectSection EndProject -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-map-insfind-int", "stress-map-insfind-int.vcxproj", "{24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}" - ProjectSection(ProjectDependencies) = postProject - {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} = {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} - {408FE9BC-44F0-4E6A-89FA-D6F952584239} = {408FE9BC-44F0-4E6A-89FA-D6F952584239} - EndProjectSection -EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-set-iteration", "stress-set-iteration.vcxproj", "{31952FA8-A303-4A0B-94C4-ABA5A8A6DBCE}" ProjectSection(ProjectDependencies) = postProject {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} = {A34CED07-A442-4FA1-81C4-F8B9CD3C832B} @@ -412,6 +394,10 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "striped-set", "striped-set" EndProject Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "tree", "tree", "{31977D29-25C2-4FEC-9176-15247A15A9B4}" EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-map-del3", "stress-map-del3.vcxproj", "{729E28BB-F36F-4462-8434-9C252C286525}" +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "stress-set-del3", "stress-set-del3.vcxproj", "{E91A1938-BB89-4676-9C9F-69AA697CB488}" +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Win32 = Debug|Win32 @@ -602,18 +588,6 @@ Global {DD432BE7-0CA8-47C6-B861-943A036C18EF}.Release|Win32.Build.0 = Release|Win32 {DD432BE7-0CA8-47C6-B861-943A036C18EF}.Release|x64.ActiveCfg = Release|x64 {DD432BE7-0CA8-47C6-B861-943A036C18EF}.Release|x64.Build.0 = Release|x64 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.Debug|Win32.ActiveCfg = Debug|Win32 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.Debug|Win32.Build.0 = Debug|Win32 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.Debug|x64.ActiveCfg = Debug|x64 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.Debug|x64.Build.0 = Debug|x64 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.DebugVLD|Win32.ActiveCfg = DebugVLD|Win32 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.DebugVLD|Win32.Build.0 = DebugVLD|Win32 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.DebugVLD|x64.ActiveCfg = DebugVLD|x64 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.DebugVLD|x64.Build.0 = DebugVLD|x64 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.Release|Win32.ActiveCfg = Release|Win32 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.Release|Win32.Build.0 = Release|Win32 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.Release|x64.ActiveCfg = Release|x64 - {3F36B97B-8028-4335-ADDD-20B6B81F87AF}.Release|x64.Build.0 = Release|x64 {C127CD80-E8A7-47E4-B7EC-1709D2188982}.Debug|Win32.ActiveCfg = Debug|Win32 {C127CD80-E8A7-47E4-B7EC-1709D2188982}.Debug|Win32.Build.0 = Debug|Win32 {C127CD80-E8A7-47E4-B7EC-1709D2188982}.Debug|x64.ActiveCfg = Debug|x64 @@ -638,18 +612,6 @@ Global {34FA4110-F17B-4AD0-A4C9-C91B92AD06E4}.Release|Win32.Build.0 = Release|Win32 {34FA4110-F17B-4AD0-A4C9-C91B92AD06E4}.Release|x64.ActiveCfg = Release|x64 {34FA4110-F17B-4AD0-A4C9-C91B92AD06E4}.Release|x64.Build.0 = Release|x64 - {46649F79-2919-4B4C-B243-08C724901F58}.Debug|Win32.ActiveCfg = Debug|Win32 - {46649F79-2919-4B4C-B243-08C724901F58}.Debug|Win32.Build.0 = Debug|Win32 - {46649F79-2919-4B4C-B243-08C724901F58}.Debug|x64.ActiveCfg = Debug|x64 - {46649F79-2919-4B4C-B243-08C724901F58}.Debug|x64.Build.0 = Debug|x64 - {46649F79-2919-4B4C-B243-08C724901F58}.DebugVLD|Win32.ActiveCfg = DebugVLD|Win32 - {46649F79-2919-4B4C-B243-08C724901F58}.DebugVLD|Win32.Build.0 = DebugVLD|Win32 - {46649F79-2919-4B4C-B243-08C724901F58}.DebugVLD|x64.ActiveCfg = DebugVLD|x64 - {46649F79-2919-4B4C-B243-08C724901F58}.DebugVLD|x64.Build.0 = DebugVLD|x64 - {46649F79-2919-4B4C-B243-08C724901F58}.Release|Win32.ActiveCfg = Release|Win32 - {46649F79-2919-4B4C-B243-08C724901F58}.Release|Win32.Build.0 = Release|Win32 - {46649F79-2919-4B4C-B243-08C724901F58}.Release|x64.ActiveCfg = Release|x64 - {46649F79-2919-4B4C-B243-08C724901F58}.Release|x64.Build.0 = Release|x64 {2D0E651D-058D-4D69-9A44-12149E6CA5BE}.Debug|Win32.ActiveCfg = Debug|Win32 {2D0E651D-058D-4D69-9A44-12149E6CA5BE}.Debug|Win32.Build.0 = Debug|Win32 {2D0E651D-058D-4D69-9A44-12149E6CA5BE}.Debug|x64.ActiveCfg = Debug|x64 @@ -686,18 +648,6 @@ Global {1BB746AC-7856-4E59-9430-51177621DC35}.Release|Win32.Build.0 = Release|Win32 {1BB746AC-7856-4E59-9430-51177621DC35}.Release|x64.ActiveCfg = Release|x64 {1BB746AC-7856-4E59-9430-51177621DC35}.Release|x64.Build.0 = Release|x64 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.Debug|Win32.ActiveCfg = Debug|Win32 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.Debug|Win32.Build.0 = Debug|Win32 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.Debug|x64.ActiveCfg = Debug|x64 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.Debug|x64.Build.0 = Debug|x64 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.DebugVLD|Win32.ActiveCfg = DebugVLD|Win32 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.DebugVLD|Win32.Build.0 = DebugVLD|Win32 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.DebugVLD|x64.ActiveCfg = DebugVLD|x64 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.DebugVLD|x64.Build.0 = DebugVLD|x64 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.Release|Win32.ActiveCfg = Release|Win32 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.Release|Win32.Build.0 = Release|Win32 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.Release|x64.ActiveCfg = Release|x64 - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A}.Release|x64.Build.0 = Release|x64 {31952FA8-A303-4A0B-94C4-ABA5A8A6DBCE}.Debug|Win32.ActiveCfg = Debug|Win32 {31952FA8-A303-4A0B-94C4-ABA5A8A6DBCE}.Debug|Win32.Build.0 = Debug|Win32 {31952FA8-A303-4A0B-94C4-ABA5A8A6DBCE}.Debug|x64.ActiveCfg = Debug|x64 @@ -1178,6 +1128,30 @@ Global {93F1FE35-2EF4-4193-B8A2-54988F61F3B8}.Release|Win32.Build.0 = Release|Win32 {93F1FE35-2EF4-4193-B8A2-54988F61F3B8}.Release|x64.ActiveCfg = Release|x64 {93F1FE35-2EF4-4193-B8A2-54988F61F3B8}.Release|x64.Build.0 = Release|x64 + {729E28BB-F36F-4462-8434-9C252C286525}.Debug|Win32.ActiveCfg = Debug|Win32 + {729E28BB-F36F-4462-8434-9C252C286525}.Debug|Win32.Build.0 = Debug|Win32 + {729E28BB-F36F-4462-8434-9C252C286525}.Debug|x64.ActiveCfg = Debug|x64 + {729E28BB-F36F-4462-8434-9C252C286525}.Debug|x64.Build.0 = Debug|x64 + {729E28BB-F36F-4462-8434-9C252C286525}.DebugVLD|Win32.ActiveCfg = DebugVLD|Win32 + {729E28BB-F36F-4462-8434-9C252C286525}.DebugVLD|Win32.Build.0 = DebugVLD|Win32 + {729E28BB-F36F-4462-8434-9C252C286525}.DebugVLD|x64.ActiveCfg = DebugVLD|x64 + {729E28BB-F36F-4462-8434-9C252C286525}.DebugVLD|x64.Build.0 = DebugVLD|x64 + {729E28BB-F36F-4462-8434-9C252C286525}.Release|Win32.ActiveCfg = Release|Win32 + {729E28BB-F36F-4462-8434-9C252C286525}.Release|Win32.Build.0 = Release|Win32 + {729E28BB-F36F-4462-8434-9C252C286525}.Release|x64.ActiveCfg = Release|x64 + {729E28BB-F36F-4462-8434-9C252C286525}.Release|x64.Build.0 = Release|x64 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.Debug|Win32.ActiveCfg = Debug|Win32 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.Debug|Win32.Build.0 = Debug|Win32 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.Debug|x64.ActiveCfg = Debug|x64 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.Debug|x64.Build.0 = Debug|x64 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.DebugVLD|Win32.ActiveCfg = DebugVLD|Win32 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.DebugVLD|Win32.Build.0 = DebugVLD|Win32 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.DebugVLD|x64.ActiveCfg = DebugVLD|x64 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.DebugVLD|x64.Build.0 = DebugVLD|x64 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.Release|Win32.ActiveCfg = Release|Win32 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.Release|Win32.Build.0 = Release|Win32 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.Release|x64.ActiveCfg = Release|x64 + {E91A1938-BB89-4676-9C9F-69AA697CB488}.Release|x64.Build.0 = Release|x64 EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE @@ -1201,14 +1175,11 @@ Global {7D3EE35B-185D-40B5-88C2-7F9933426978} = {10E1FAF2-904D-405E-8AB5-6878A1B03346} {2C41747C-6CC6-4AE8-9EB8-EB8B954BBDB4} = {7D3EE35B-185D-40B5-88C2-7F9933426978} {DD432BE7-0CA8-47C6-B861-943A036C18EF} = {7D3EE35B-185D-40B5-88C2-7F9933426978} - {3F36B97B-8028-4335-ADDD-20B6B81F87AF} = {7D3EE35B-185D-40B5-88C2-7F9933426978} {C127CD80-E8A7-47E4-B7EC-1709D2188982} = {7D3EE35B-185D-40B5-88C2-7F9933426978} {34FA4110-F17B-4AD0-A4C9-C91B92AD06E4} = {7D3EE35B-185D-40B5-88C2-7F9933426978} - {46649F79-2919-4B4C-B243-08C724901F58} = {7D3EE35B-185D-40B5-88C2-7F9933426978} {2D0E651D-058D-4D69-9A44-12149E6CA5BE} = {7D3EE35B-185D-40B5-88C2-7F9933426978} {50387CA5-F5B2-4C40-ACFD-FC3C9EE2CD6B} = {7D3EE35B-185D-40B5-88C2-7F9933426978} {1BB746AC-7856-4E59-9430-51177621DC35} = {7D3EE35B-185D-40B5-88C2-7F9933426978} - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A} = {7D3EE35B-185D-40B5-88C2-7F9933426978} {31952FA8-A303-4A0B-94C4-ABA5A8A6DBCE} = {0D83E8C7-97D1-4BA1-928A-6846E7089652} {79A6845E-85BF-4000-94FF-9DF2473460D4} = {10E1FAF2-904D-405E-8AB5-6878A1B03346} {F6B51C66-CFFF-495F-8012-5D5DD5BC8A48} = {10DC2D86-83B3-428A-8190-463EF4ED03E3} @@ -1257,6 +1228,8 @@ Global {DE3B8DBB-5B4B-40DC-80DB-F0C15BC21E0F} = {810490B7-31E5-49AE-8455-CAF99A9658B6} {E0C742CB-A36A-4617-8A06-DD4820FEB8ED} = {810490B7-31E5-49AE-8455-CAF99A9658B6} {31977D29-25C2-4FEC-9176-15247A15A9B4} = {810490B7-31E5-49AE-8455-CAF99A9658B6} + {729E28BB-F36F-4462-8434-9C252C286525} = {7D3EE35B-185D-40B5-88C2-7F9933426978} + {E91A1938-BB89-4676-9C9F-69AA697CB488} = {0D83E8C7-97D1-4BA1-928A-6846E7089652} EndGlobalSection GlobalSection(DPCodeReviewSolutionGUID) = preSolution DPCodeReviewSolutionGUID = {00000000-0000-0000-0000-000000000000} diff --git a/projects/Win/vc14/stress-freelist.vcxproj.filters b/projects/Win/vc14/stress-freelist.vcxproj.filters deleted file mode 100644 index d7e0247e..00000000 --- a/projects/Win/vc14/stress-freelist.vcxproj.filters +++ /dev/null @@ -1,24 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-find_int.vcxproj b/projects/Win/vc14/stress-map-del3.vcxproj similarity index 93% rename from projects/Win/vc14/stress-map-find_int.vcxproj rename to projects/Win/vc14/stress-map-del3.vcxproj index 8f08222c..66f0ae20 100644 --- a/projects/Win/vc14/stress-map-find_int.vcxproj +++ b/projects/Win/vc14/stress-map-del3.vcxproj @@ -28,9 +28,9 @@ - - - + + + _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) @@ -38,11 +38,11 @@ _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) - - - - - + + + + + 4503 4503 4503 @@ -50,21 +50,19 @@ 4503 4503 - - - + - + - {3F36B97B-8028-4335-ADDD-20B6B81F87AF} + {729E28BB-F36F-4462-8434-9C252C286525} Win32Proj - stress_map_find_int + stress_map_del3 8.1 - stress-map-find_int + stress-map-del3 diff --git a/projects/Win/vc14/stress-map-delodd.vcxproj.filters b/projects/Win/vc14/stress-map-delodd.vcxproj.filters deleted file mode 100644 index 4d1c134e..00000000 --- a/projects/Win/vc14/stress-map-delodd.vcxproj.filters +++ /dev/null @@ -1,50 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-find_int.vcxproj.filters b/projects/Win/vc14/stress-map-find_int.vcxproj.filters deleted file mode 100644 index 4ae67ebe..00000000 --- a/projects/Win/vc14/stress-map-find_int.vcxproj.filters +++ /dev/null @@ -1,56 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-find_string.vcxproj.filters b/projects/Win/vc14/stress-map-find_string.vcxproj.filters deleted file mode 100644 index 1a17e3bc..00000000 --- a/projects/Win/vc14/stress-map-find_string.vcxproj.filters +++ /dev/null @@ -1,56 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - - - - Header Files - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-insdel-func.vcxproj.filters b/projects/Win/vc14/stress-map-insdel-func.vcxproj.filters deleted file mode 100644 index 1a3164fa..00000000 --- a/projects/Win/vc14/stress-map-insdel-func.vcxproj.filters +++ /dev/null @@ -1,53 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-insdel-int.vcxproj b/projects/Win/vc14/stress-map-insdel-int.vcxproj deleted file mode 100644 index 8f0b642a..00000000 --- a/projects/Win/vc14/stress-map-insdel-int.vcxproj +++ /dev/null @@ -1,273 +0,0 @@ - - - - - DebugVLD - Win32 - - - DebugVLD - x64 - - - Debug - Win32 - - - Release - Win32 - - - Debug - x64 - - - Release - x64 - - - - - - - - _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) - _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) - _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) - _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) - _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) - _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) - - - - - - - 4503 - 4503 - 4503 - 4503 - 4503 - 4503 - - - - - - - - - - - - {46649F79-2919-4B4C-B243-08C724901F58} - Win32Proj - stress_map_insdel_int - 8.1 - stress-map-insdel-int - - - - Application - true - v140 - Unicode - - - Application - true - v140 - Unicode - - - Application - false - v140 - true - Unicode - - - Application - true - v140 - Unicode - - - Application - true - v140 - Unicode - - - Application - false - v140 - true - Unicode - - - - - - - - - - - - - - - - - - - - - - - - - - - true - $(SolutionDir)..\..\..\bin\vc.$(PlatformToolset)\$(Platform)\ - $(SolutionDir)..\..\..\obj\vc.$(PlatformToolset)\$(Platform)\$(ProjectName)\$(Configuration)\ - $(ProjectName)_d - - - true - $(SolutionDir)..\..\..\bin\vc.$(PlatformToolset)\$(Platform)\ - $(SolutionDir)..\..\..\obj\vc.$(PlatformToolset)\$(Platform)\$(ProjectName)\$(Configuration)\ - $(ProjectName)_d - - - true - $(SolutionDir)..\..\..\bin\vc.$(PlatformToolset)\$(Platform)\ - $(SolutionDir)..\..\..\obj\vc.$(PlatformToolset)\$(Platform)\$(ProjectName)\$(Configuration)\ - $(ProjectName)_d - - - true - $(SolutionDir)..\..\..\bin\vc.$(PlatformToolset)\$(Platform)\ - $(SolutionDir)..\..\..\obj\vc.$(PlatformToolset)\$(Platform)\$(ProjectName)\$(Configuration)\ - $(ProjectName)_d - - - false - $(SolutionDir)..\..\..\bin\vc.$(PlatformToolset)\$(Platform)-release\ - $(SolutionDir)..\..\..\obj\vc.$(PlatformToolset)\$(Platform)\$(ProjectName)\$(Configuration)\ - - - false - $(SolutionDir)..\..\..\bin\vc.$(PlatformToolset)\$(Platform)-release\ - $(SolutionDir)..\..\..\obj\vc.$(PlatformToolset)\$(Platform)\$(ProjectName)\$(Configuration)\ - - - - NotUsing - Level3 - Disabled - _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) - /bigobj %(AdditionalOptions) - - - Console - DebugFastLink - $(GTEST_LIB32);$(GTEST_ROOT)/lib/x86;$(BOOST_PATH)/stage32/lib;$(BOOST_PATH)/stage/lib;$(BOOST_PATH)/bin;%(AdditionalLibraryDirectories);$(OutDir) - gtestd.lib;stress-framework_d.lib;%(AdditionalDependencies) - - - - - NotUsing - Level3 - Disabled - _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) - /bigobj %(AdditionalOptions) - - - Console - DebugFastLink - $(GTEST_LIB32);$(GTEST_ROOT)/lib/x86;$(BOOST_PATH)/stage32/lib;$(BOOST_PATH)/stage/lib;$(BOOST_PATH)/bin;%(AdditionalLibraryDirectories);$(OutDir) - gtestd.lib;stress-framework_d.lib;%(AdditionalDependencies) - - - - - NotUsing - Level3 - Disabled - _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) - /bigobj %(AdditionalOptions) - - - Console - DebugFastLink - $(GTEST_LIB64);$(GTEST_ROOT)/lib/x64;$(BOOST_PATH)/stage64/lib;$(BOOST_PATH)/bin;%(AdditionalLibraryDirectories);$(OutDir) - gtestd.lib;stress-framework_d.lib;%(AdditionalDependencies) - - - - - NotUsing - Level3 - Disabled - _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) - /bigobj %(AdditionalOptions) - - - Console - DebugFastLink - $(GTEST_LIB64);$(GTEST_ROOT)/lib/x64;$(BOOST_PATH)/stage64/lib;$(BOOST_PATH)/bin;%(AdditionalLibraryDirectories);$(OutDir) - gtestd.lib;stress-framework_d.lib;%(AdditionalDependencies) - - - - - Level3 - NotUsing - MaxSpeed - true - true - _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) - /bigobj %(AdditionalOptions) - - - Console - true - true - true - $(GTEST_LIB32);$(GTEST_ROOT)/lib/x86;$(BOOST_PATH)/stage32/lib;$(BOOST_PATH)/stage/lib;$(BOOST_PATH)/bin;%(AdditionalLibraryDirectories);$(OutDir) - gtest.lib;stress-framework.lib;%(AdditionalDependencies) - - - - - Level3 - NotUsing - MaxSpeed - true - true - _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) - /bigobj %(AdditionalOptions) - - - Console - true - true - true - $(GTEST_LIB64);$(GTEST_ROOT)/lib/x64;$(BOOST_PATH)/stage64/lib;$(BOOST_PATH)/bin;%(AdditionalLibraryDirectories);$(OutDir) - gtest.lib;stress-framework.lib;%(AdditionalDependencies) - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-insdel-int.vcxproj.filters b/projects/Win/vc14/stress-map-insdel-int.vcxproj.filters deleted file mode 100644 index 8a250daa..00000000 --- a/projects/Win/vc14/stress-map-insdel-int.vcxproj.filters +++ /dev/null @@ -1,56 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-insdel-item-int.vcxproj.filters b/projects/Win/vc14/stress-map-insdel-item-int.vcxproj.filters deleted file mode 100644 index 4ef82f69..00000000 --- a/projects/Win/vc14/stress-map-insdel-item-int.vcxproj.filters +++ /dev/null @@ -1,53 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-insdel-string.vcxproj.filters b/projects/Win/vc14/stress-map-insdel-string.vcxproj.filters deleted file mode 100644 index 46a38802..00000000 --- a/projects/Win/vc14/stress-map-insdel-string.vcxproj.filters +++ /dev/null @@ -1,56 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-insdelfind.vcxproj.filters b/projects/Win/vc14/stress-map-insdelfind.vcxproj.filters deleted file mode 100644 index f9cd9705..00000000 --- a/projects/Win/vc14/stress-map-insdelfind.vcxproj.filters +++ /dev/null @@ -1,56 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-insfind-int.vcxproj.filters b/projects/Win/vc14/stress-map-insfind-int.vcxproj.filters deleted file mode 100644 index da30273c..00000000 --- a/projects/Win/vc14/stress-map-insfind-int.vcxproj.filters +++ /dev/null @@ -1,56 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-map-insfind-int.vcxproj b/projects/Win/vc14/stress-set-del3.vcxproj similarity index 91% rename from projects/Win/vc14/stress-map-insfind-int.vcxproj rename to projects/Win/vc14/stress-set-del3.vcxproj index 42f2973a..c9917937 100644 --- a/projects/Win/vc14/stress-map-insfind-int.vcxproj +++ b/projects/Win/vc14/stress-set-del3.vcxproj @@ -28,9 +28,8 @@ - - - + + _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) @@ -38,11 +37,11 @@ _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) _SCL_SECURE_NO_WARNINGS;%(PreprocessorDefinitions) - - - - - + + + + + 4503 4503 4503 @@ -50,21 +49,19 @@ 4503 4503 - - - + - + - {24DF3B87-387E-4EFC-BDE0-8DAD279FE19A} + {E91A1938-BB89-4676-9C9F-69AA697CB488} Win32Proj - stress_map_insfind_int + stress_set_del3 8.1 - stress-map-insfind-int + stress-set-del3 @@ -169,7 +166,7 @@ Level3 Disabled _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) + $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\set;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) /bigobj %(AdditionalOptions) @@ -185,7 +182,7 @@ Level3 Disabled _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) + $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\set;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) /bigobj %(AdditionalOptions) @@ -201,7 +198,7 @@ Level3 Disabled _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) + $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\set;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) /bigobj %(AdditionalOptions) @@ -217,7 +214,7 @@ Level3 Disabled _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) + $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\set;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) /bigobj %(AdditionalOptions) @@ -235,7 +232,7 @@ true true _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) + $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\set;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) /bigobj %(AdditionalOptions) @@ -255,7 +252,7 @@ true true _ENABLE_ATOMIC_ALIGNMENT_FIX;CDSUNIT_USE_URCU;CDS_ENABLE_HPSTAT;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) - $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\map;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) + $(SolutionDir)..\..\..;$(GTEST_ROOT)/include;$(SolutionDir)..\..\..\test\include;$(SolutionDir)..\..\..\test\stress\set;$(SolutionDir)..\..\..\test\stress\;$(BOOST_PATH);%(AdditionalIncludeDirectories) /bigobj %(AdditionalOptions) diff --git a/projects/Win/vc14/stress-set-delodd.vcxproj.filters b/projects/Win/vc14/stress-set-delodd.vcxproj.filters deleted file mode 100644 index 5198fb4a..00000000 --- a/projects/Win/vc14/stress-set-delodd.vcxproj.filters +++ /dev/null @@ -1,47 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-set-insdel_func.vcxproj.filters b/projects/Win/vc14/stress-set-insdel_func.vcxproj.filters deleted file mode 100644 index 982c2cbb..00000000 --- a/projects/Win/vc14/stress-set-insdel_func.vcxproj.filters +++ /dev/null @@ -1,50 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-set-insdel_string.vcxproj.filters b/projects/Win/vc14/stress-set-insdel_string.vcxproj.filters deleted file mode 100644 index 4d54e925..00000000 --- a/projects/Win/vc14/stress-set-insdel_string.vcxproj.filters +++ /dev/null @@ -1,53 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-set-insdelfind.vcxproj.filters b/projects/Win/vc14/stress-set-insdelfind.vcxproj.filters deleted file mode 100644 index 86b0eabe..00000000 --- a/projects/Win/vc14/stress-set-insdelfind.vcxproj.filters +++ /dev/null @@ -1,53 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/projects/Win/vc14/stress-set-iteration.vcxproj.filters b/projects/Win/vc14/stress-set-iteration.vcxproj.filters deleted file mode 100644 index 99479b58..00000000 --- a/projects/Win/vc14/stress-set-iteration.vcxproj.filters +++ /dev/null @@ -1,38 +0,0 @@ - - - - - {4FC737F1-C7A5-4376-A066-2A32D752A2FF} - cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx - - - {93995380-89BD-4b04-88EB-625FBE52EBFB} - h;hh;hpp;hxx;hm;inl;inc;xsd - - - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - Source Files - - - - - Header Files - - - - - - \ No newline at end of file diff --git a/test/stress/map/CMakeLists.txt b/test/stress/map/CMakeLists.txt index 7428b22e..e5d8ba8a 100644 --- a/test/stress/map/CMakeLists.txt +++ b/test/stress/map/CMakeLists.txt @@ -2,27 +2,20 @@ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DCDSUNIT_USE_URCU") add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/delodd) -add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/find_int) +add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/del3) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/find_string) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdel_func) -add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdel_int) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdel_string) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdel_item_int) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdelfind) -add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insfind_int) -#add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdel_find) -#add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdel_func) -#add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdel_string) add_custom_target( stress-map DEPENDS stress-map-delodd - stress-map-find-int + stress-map-del3 stress-map-find-string stress-map-insdel-func - stress-map-insdel-int stress-map-insdel-string stress-map-insdel-item-int stress-map-insdelfind - stress-map-insfind-int ) diff --git a/test/stress/map/del3/CMakeLists.txt b/test/stress/map/del3/CMakeLists.txt new file mode 100644 index 00000000..1e92695f --- /dev/null +++ b/test/stress/map/del3/CMakeLists.txt @@ -0,0 +1,29 @@ +set(PACKAGE_NAME stress-map-del3) + +set(CDSSTRESS_MAP_DEL3_SOURCES + ../../main.cpp + map_del3.cpp + map_del3_bronsonavltree.cpp + map_del3_cuckoo.cpp + map_del3_ellentree.cpp + map_del3_feldman_hashmap.cpp + map_del3_michael.cpp + map_del3_skip.cpp + map_del3_split.cpp +) + +include_directories( + ${CMAKE_CURRENT_SOURCE_DIR} + ${CMAKE_CURRENT_SOURCE_DIR}/.. +) + +add_executable(${PACKAGE_NAME} ${CDSSTRESS_MAP_DEL3_SOURCES} $) +target_link_libraries(${PACKAGE_NAME} + ${CDS_SHARED_LIBRARY} + ${GTEST_LIBRARY} + ${Boost_THREAD_LIBRARY} + ${Boost_SYSTEM_LIBRARY} + ${CMAKE_THREAD_LIBS_INIT} +) + +add_test(NAME ${PACKAGE_NAME} COMMAND ${PACKAGE_NAME} WORKING_DIRECTORY ${EXECUTABLE_OUTPUT_PATH}) \ No newline at end of file diff --git a/test/stress/map/find_int/map_find_int.cpp b/test/stress/map/del3/map_del3.cpp similarity index 62% rename from test/stress/map/find_int/map_find_int.cpp rename to test/stress/map/del3/map_del3.cpp index dfc516a8..dddad6b3 100644 --- a/test/stress/map/find_int/map_find_int.cpp +++ b/test/stress/map/del3/map_del3.cpp @@ -28,65 +28,52 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_find_int.h" +#include "map_del3.h" namespace map { - size_t Map_find_int::s_nThreadCount = 8; - size_t Map_find_int::s_nMapSize = 10000000; - size_t Map_find_int::s_nMaxLoadFactor = 8; - size_t Map_find_int::s_nPercentExists = 50; - size_t Map_find_int::s_nPassCount = 2; + size_t Map_Del3::s_nMapSize = 10000; + size_t Map_Del3::s_nInsThreadCount = 4; + size_t Map_Del3::s_nDelThreadCount = 4; + size_t Map_Del3::s_nExtractThreadCount = 4; + size_t Map_Del3::s_nFindThreadCount = 2; + size_t Map_Del3::s_nMaxLoadFactor = 8; + size_t Map_Del3::s_nInsertPassCount = 100; - size_t Map_find_int::s_nCuckooInitialSize = 1024; - size_t Map_find_int::s_nCuckooProbesetSize = 16; - size_t Map_find_int::s_nCuckooProbesetThreshold = 0; + size_t Map_Del3::s_nCuckooInitialSize = 1024; + size_t Map_Del3::s_nCuckooProbesetSize = 16; + size_t Map_Del3::s_nCuckooProbesetThreshold = 0; - size_t Map_find_int::s_nFeldmanMap_HeadBits = 10; - size_t Map_find_int::s_nFeldmanMap_ArrayBits = 4; + size_t Map_Del3::s_nFeldmanMap_HeadBits = 10; + size_t Map_Del3::s_nFeldmanMap_ArrayBits = 4; + size_t Map_Del3::s_nLoadFactor = 1; + std::vector Map_Del3::m_arrElements; - size_t Map_find_int::s_nLoadFactor = 1; - size_t Map_find_int::s_nRealMapSize = 0; - Map_find_int::value_vector Map_find_int::s_Data; - - void Map_find_int::generateSequence() - { - size_t nPercent = s_nPercentExists; - - if ( nPercent > 100 ) - nPercent = 100; - else if ( nPercent < 1 ) - nPercent = 1; - - s_nRealMapSize = 0; - - s_Data.resize( s_nMapSize ); - for ( size_t i = 0; i < s_nMapSize; ++i ) { - s_Data[i].nKey = i * 13; - s_Data[i].bExists = rand( 100 ) <= nPercent; - if ( s_Data[i].bExists ) - ++s_nRealMapSize; - } - shuffle( s_Data.begin(), s_Data.end()); - } - - void Map_find_int::SetUpTestCase() + void Map_Del3::SetUpTestCase() { - cds_test::config const& cfg = get_config( "map_find_int" ); + cds_test::config const& cfg = get_config( "map_delodd" ); s_nMapSize = cfg.get_size_t( "MapSize", s_nMapSize ); if ( s_nMapSize < 1000 ) s_nMapSize = 1000; - s_nThreadCount = cfg.get_size_t( "ThreadCount", s_nThreadCount ); - if ( s_nThreadCount == 0 ) - s_nThreadCount = 1; + s_nInsThreadCount = cfg.get_size_t( "InsThreadCount", s_nInsThreadCount ); + if ( s_nInsThreadCount == 0 ) + s_nInsThreadCount = 1; + + s_nDelThreadCount = cfg.get_size_t( "DelThreadCount", s_nDelThreadCount ); + s_nExtractThreadCount = cfg.get_size_t( "ExtractThreadCount", s_nExtractThreadCount ); + s_nFindThreadCount = cfg.get_size_t( "FindThreadCount", s_nFindThreadCount ); s_nMaxLoadFactor = cfg.get_size_t( "MaxLoadFactor", s_nMaxLoadFactor ); if ( s_nMaxLoadFactor == 0 ) s_nMaxLoadFactor = 1; + s_nInsertPassCount = cfg.get_size_t( "PassCount", s_nInsertPassCount ); + if ( s_nInsertPassCount == 0 ) + s_nInsertPassCount = 100; + s_nCuckooInitialSize = cfg.get_size_t( "CuckooInitialSize", s_nCuckooInitialSize ); if ( s_nCuckooInitialSize < 256 ) s_nCuckooInitialSize = 256; @@ -105,17 +92,20 @@ namespace map { if ( s_nFeldmanMap_ArrayBits == 0 ) s_nFeldmanMap_ArrayBits = 2; - generateSequence(); + m_arrElements.resize( s_nMapSize ); + for ( size_t i = 0; i < s_nMapSize; ++i ) + m_arrElements[i] = i;; + shuffle( m_arrElements.begin(), m_arrElements.end()); } - void Map_find_int::TearDownTestCase() + void Map_Del3::TearDownTestCase() { - s_Data.clear(); + m_arrElements.clear(); } - std::vector Map_find_int_LF::get_load_factors() + std::vector Map_Del3_LF::get_load_factors() { - cds_test::config const& cfg = get_config( "map_find_int" ); + cds_test::config const& cfg = get_config( "map_delodd" ); s_nMaxLoadFactor = cfg.get_size_t( "MaxLoadFactor", s_nMaxLoadFactor ); if ( s_nMaxLoadFactor == 0 ) @@ -128,5 +118,5 @@ namespace map { return lf; } - INSTANTIATE_TEST_CASE_P( a, Map_find_int_LF, ::testing::ValuesIn( Map_find_int_LF::get_load_factors())); + INSTANTIATE_TEST_CASE_P( a, Map_Del3_LF, ::testing::ValuesIn( Map_Del3_LF::get_load_factors())); } // namespace map diff --git a/test/stress/map/del3/map_del3.h b/test/stress/map/del3/map_del3.h new file mode 100644 index 00000000..b6ffb891 --- /dev/null +++ b/test/stress/map/del3/map_del3.h @@ -0,0 +1,881 @@ +/* + This file is a part of libcds - Concurrent Data Structures library + + (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 + + Source code repo: http://github.com/khizmax/libcds/ + Download: http://sourceforge.net/projects/libcds/files/ + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE + FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER + CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, + OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +*/ + +#include "map_type.h" +#include + +namespace map { + + namespace { + struct key_thread + { + uint32_t nKey; + uint16_t nThread; + + key_thread( size_t key, size_t threadNo ) + : nKey( static_cast(key)) + , nThread( static_cast(threadNo)) + {} + + key_thread() + : nKey() + , nThread() + {} + }; + + static_assert(sizeof( key_thread ) % 8 == 0, "Key size mismatch!!!"); + } // namespace + + template <> + struct cmp { + int operator ()(key_thread const& k1, key_thread const& k2) const + { + if ( k1.nKey < k2.nKey ) + return -1; + if ( k1.nKey > k2.nKey ) + return 1; + if ( k1.nThread < k2.nThread ) + return -1; + if ( k1.nThread > k2.nThread ) + return 1; + return 0; + } + int operator ()(key_thread const& k1, size_t k2) const + { + if ( k1.nKey < k2 ) + return -1; + if ( k1.nKey > k2 ) + return 1; + return 0; + } + int operator ()(size_t k1, key_thread const& k2) const + { + if ( k1 < k2.nKey ) + return -1; + if ( k1 > k2.nKey ) + return 1; + return 0; + } + }; + + template <> + struct less + { + bool operator()( key_thread const& k1, key_thread const& k2 ) const + { + if ( k1.nKey <= k2.nKey ) + return k1.nKey < k2.nKey || k1.nThread < k2.nThread; + return false; + } + }; + + template <> + struct hash + { + typedef size_t result_type; + typedef key_thread argument_type; + + size_t operator()( key_thread const& k ) const + { + return std::hash()(k.nKey); + } + size_t operator()( size_t k ) const + { + return std::hash()(k); + } + }; + + class Map_Del3: public cds_test::stress_fixture + { + public: + static size_t s_nInsThreadCount; // insert thread count + static size_t s_nDelThreadCount; // delete thread count + static size_t s_nExtractThreadCount; // extract thread count + static size_t s_nMapSize; // max map size + static size_t s_nMaxLoadFactor; // maximum load factor + static size_t s_nInsertPassCount; + static size_t s_nFindThreadCount; // find thread count + + static size_t s_nCuckooInitialSize; // initial size for CuckooMap + static size_t s_nCuckooProbesetSize; // CuckooMap probeset size (only for list-based probeset) + static size_t s_nCuckooProbesetThreshold; // CuckooMap probeset threshold (0 - use default) + + static size_t s_nFeldmanMap_HeadBits; + static size_t s_nFeldmanMap_ArrayBits; + + static size_t s_nLoadFactor; // current load factor + + static std::vector m_arrElements; + + static void SetUpTestCase(); + static void TearDownTestCase(); + + template + static void prepare_array( std::vector& arr, Pred pred ) + { + arr.reserve( m_arrElements.size()); + for ( auto el : m_arrElements ) { + if ( pred( el )) + arr.push_back( el ); + } + arr.resize( arr.size()); + shuffle( arr.begin(), arr.end()); + } + + protected: + typedef key_thread key_type; + typedef size_t value_type; + typedef std::pair pair_type; + + atomics::atomic m_nInsThreadCount; + + enum { + inserter_thread, + deleter_thread, + extractor_thread, + find_thread, + }; + + // Inserts keys from [0..N) + template + class Inserter: public cds_test::thread + { + typedef cds_test::thread base_class; + Map& m_Map; + + struct update_func + { + template + void operator()( bool /*bNew*/, Q const& ) const + {} + + template + void operator()( bool /*bNew*/, Q const&, V& ) const + {} + + // FeldmanHashMap + template + void operator()( Q&, Q*) const + {} + }; + + void init_data() + { + prepare_array( m_arr, []( size_t ) -> bool { return true; } ); + for ( size_t i = 0; i < m_arr.size(); ++i ) { + if ( m_Map.insert( key_type( m_arr[i], id()))) + ++m_nInsertInitSuccess; + else + ++m_nInsertInitFailed; + } + } + + public: + size_t m_nInsertSuccess = 0; + size_t m_nInsertFailed = 0; + size_t m_nInsertInitSuccess = 0; + size_t m_nInsertInitFailed = 0; + + std::vector m_arr; + + public: + Inserter( cds_test::thread_pool& pool, Map& map ) + : base_class( pool, inserter_thread ) + , m_Map( map ) + { + init_data(); + } + + Inserter( Inserter& src ) + : base_class( src ) + , m_Map( src.m_Map ) + { + init_data(); + } + + virtual thread * clone() + { + return new Inserter( *this ); + } + + virtual void test() + { + Map& rMap = m_Map; + Map_Del3& fixture = pool().template fixture(); + + update_func f; + + for ( size_t nPass = 0; nPass < s_nInsertPassCount; ++nPass ) { + if ( nPass & 1 ) { + // insert pass + for ( auto el : m_arr ) { + if ( el & 3 ) { + if ( rMap.insert( key_type( el, id()))) + ++m_nInsertSuccess; + else + ++m_nInsertFailed; + } + } + } + else { + // update pass + for ( auto el : m_arr ) { + if ( el & 3 ) { + bool success; + bool inserted; + std::tie( success, inserted ) = rMap.update( key_type( el, id()), f ); + if ( success && inserted ) + ++m_nInsertSuccess; + else + ++m_nInsertFailed; + } + } + } + } + + fixture.m_nInsThreadCount.fetch_sub( 1, atomics::memory_order_release ); + m_arr.resize( 0 ); + } + }; + + struct key_equal { + bool operator()( key_type const& k1, key_type const& k2 ) const + { + return k1.nKey == k2.nKey; + } + bool operator()( size_t k1, key_type const& k2 ) const + { + return k1 == k2.nKey; + } + bool operator()( key_type const& k1, size_t k2 ) const + { + return k1.nKey == k2; + } + }; + + struct key_less { + bool operator()( key_type const& k1, key_type const& k2 ) const + { + return k1.nKey < k2.nKey; + } + bool operator()( size_t k1, key_type const& k2 ) const + { + return k1 < k2.nKey; + } + bool operator()( key_type const& k1, size_t k2 ) const + { + return k1.nKey < k2; + } + + typedef key_equal equal_to; + }; + + // Deletes odd keys from [0..N) + template + class Deleter: public cds_test::thread + { + typedef cds_test::thread base_class; + Map& m_Map; + + void init_data() + { + prepare_array( m_arr, []( size_t el ) ->bool { return ( el & 3 ) != 0; } ); + } + + public: + size_t m_nDeleteSuccess = 0; + size_t m_nDeleteFailed = 0; + + std::vector m_arr; + + public: + Deleter( cds_test::thread_pool& pool, Map& map ) + : base_class( pool, deleter_thread ) + , m_Map( map ) + { + init_data(); + } + + Deleter( Deleter& src ) + : base_class( src ) + , m_Map( src.m_Map ) + { + init_data(); + } + + virtual thread * clone() + { + return new Deleter( *this ); + } + + virtual void test() + { + Map& rMap = m_Map; + + Map_Del3& fixture = pool().template fixture(); + size_t const nInsThreadCount = s_nInsThreadCount; + + do { + if ( id() & 1 ) { + for ( auto el: m_arr ) { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + if ( rMap.erase( key_type( el, k ))) + ++m_nDeleteSuccess; + else + ++m_nDeleteFailed; + } + } + } + else { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + for ( auto el: m_arr ) { + if ( rMap.erase( key_type( el, k ))) + ++m_nDeleteSuccess; + else + ++m_nDeleteFailed; + } + } + } + } while ( fixture.m_nInsThreadCount.load( atomics::memory_order_acquire ) != 0 ); + + m_arr.resize( 0 ); + } + }; + + // Deletes odd keys from [0..N) + template + class Extractor: public cds_test::thread + { + typedef cds_test::thread base_class; + Map& m_Map; + + void init_data() + { + prepare_array( m_arr, []( size_t el ) ->bool { return ( el & 3 ) != 0; } ); + } + + public: + size_t m_nDeleteSuccess = 0; + size_t m_nDeleteFailed = 0; + + std::vector m_arr; + + public: + Extractor( cds_test::thread_pool& pool, Map& map ) + : base_class( pool, extractor_thread ) + , m_Map( map ) + { + init_data(); + } + + Extractor( Extractor& src ) + : base_class( src ) + , m_Map( src.m_Map ) + { + init_data(); + } + + virtual thread * clone() + { + return new Extractor( *this ); + } + + virtual void test() + { + Map& rMap = m_Map; + + typename Map::guarded_ptr gp; + Map_Del3& fixture = pool().template fixture(); + size_t const nInsThreadCount = s_nInsThreadCount; + + do { + if ( id() & 1 ) { + for ( auto el : m_arr ) { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + gp = rMap.extract( key_type( el, k )); + if ( gp ) + ++m_nDeleteSuccess; + else + ++m_nDeleteFailed; + gp.release(); + } + } + } + else { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + for ( auto el: m_arr ) { + gp = rMap.extract( key_type( el, k )); + if ( gp ) + ++m_nDeleteSuccess; + else + ++m_nDeleteFailed; + gp.release(); + } + } + } + } while ( fixture.m_nInsThreadCount.load( atomics::memory_order_acquire ) != 0 ); + + m_arr.resize( 0 ); + } + }; + + template + class Extractor< cds::urcu::gc, Map > : public cds_test::thread + { + typedef cds_test::thread base_class; + Map& m_Map; + + void init_data() + { + prepare_array( m_arr, []( size_t el ) -> bool { return ( el & 3 ) != 0; } ); + } + + public: + size_t m_nDeleteSuccess = 0; + size_t m_nDeleteFailed = 0; + + std::vector m_arr; + + public: + Extractor( cds_test::thread_pool& pool, Map& map ) + : base_class( pool, extractor_thread ) + , m_Map( map ) + { + init_data(); + } + + Extractor( Extractor& src ) + : base_class( src ) + , m_Map( src.m_Map ) + { + init_data(); + } + + virtual thread * clone() + { + return new Extractor( *this ); + } + + virtual void test() + { + Map& rMap = m_Map; + Map_Del3& fixture = pool().template fixture(); + + typename Map::exempt_ptr xp; + size_t const nInsThreadCount = s_nInsThreadCount; + + do { + if ( id() & 1 ) { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + for ( auto el: m_arr ) { + if ( Map::c_bExtractLockExternal ) { + typename Map::rcu_lock l; + xp = rMap.extract( key_type( el, k )); + if ( xp ) + ++m_nDeleteSuccess; + else + ++m_nDeleteFailed; + } + else { + xp = rMap.extract( key_type( el, k )); + if ( xp ) + ++m_nDeleteSuccess; + else + ++m_nDeleteFailed; + } + xp.release(); + } + } + } + else { + for ( auto el : m_arr ) { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + if ( Map::c_bExtractLockExternal ) { + typename Map::rcu_lock l; + xp = rMap.extract( key_type( el, k )); + if ( xp ) + ++m_nDeleteSuccess; + else + ++m_nDeleteFailed; + } + else { + xp = rMap.extract( key_type( el, k )); + if ( xp ) + ++m_nDeleteSuccess; + else + ++m_nDeleteFailed; + } + xp.release(); + } + } + } + } while ( fixture.m_nInsThreadCount.load( atomics::memory_order_acquire ) != 0 ); + + m_arr.resize( 0 ); + } + }; + + // Finds keys + template + class Observer: public cds_test::thread + { + typedef cds_test::thread base_class; + Map& m_Map; + + public: + size_t m_nFindEvenSuccess = 0; + size_t m_nFindEvenFailed = 0; + size_t m_nFindOddSuccess = 0; + size_t m_nFindOddFailed = 0; + + public: + Observer( cds_test::thread_pool& pool, Map& map ) + : base_class( pool, find_thread ) + , m_Map( map ) + {} + + Observer( Observer& src ) + : base_class( src ) + , m_Map( src.m_Map ) + {} + + virtual thread * clone() + { + return new Observer( *this ); + } + + virtual void test() + { + Map& map = m_Map; + Map_Del3& fixture = pool().template fixture(); + std::vector const& arr = m_arrElements; + size_t const nInsThreadCount = s_nInsThreadCount; + + do { + for ( size_t key : arr ) { + if ( key & 3 ) { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + if ( map.contains( key_thread( key, k ))) + ++m_nFindOddSuccess; + else + ++m_nFindOddFailed; + } + } + else { + // even keys MUST be in the map + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + if ( map.contains( key_thread( key, k ))) + ++m_nFindEvenSuccess; + else + ++m_nFindEvenFailed; + } + } + } + } while ( fixture.m_nInsThreadCount.load( atomics::memory_order_acquire ) != 0 ); + } + }; + + protected: + template + void do_test( Map& testMap ) + { + typedef Inserter insert_thread; + typedef Deleter delete_thread; + typedef Observer observer_thread; + + m_nInsThreadCount.store( s_nInsThreadCount, atomics::memory_order_release ); + + cds_test::thread_pool& pool = get_pool(); + pool.add( new insert_thread( pool, testMap ), s_nInsThreadCount ); + pool.add( new delete_thread( pool, testMap ), s_nDelThreadCount ? s_nDelThreadCount : cds::OS::topology::processor_count()); + if ( s_nFindThreadCount ) + pool.add( new observer_thread( pool, testMap ), s_nFindThreadCount ); + + propout() << std::make_pair( "insert_thread_count", s_nInsThreadCount ) + << std::make_pair( "delete_thread_count", s_nDelThreadCount ) + << std::make_pair( "find_thread_count", s_nFindThreadCount ) + << std::make_pair( "map_size", s_nMapSize ) + << std::make_pair( "pass_count", s_nInsertPassCount ); + + std::chrono::milliseconds duration = pool.run(); + + propout() << std::make_pair( "duration", duration ); + + size_t nInsertInitFailed = 0; + size_t nInsertInitSuccess = 0; + size_t nInsertSuccess = 0; + size_t nInsertFailed = 0; + size_t nDeleteSuccess = 0; + size_t nDeleteFailed = 0; + + size_t nFindEvenSuccess = 0; + size_t nFindEvenFailed = 0; + size_t nFindOddSuccess = 0; + size_t nFindOddFailed = 0; + + for ( size_t i = 0; i < pool.size(); ++i ) { + cds_test::thread& thr = pool.get( i ); + switch ( thr.type()) { + case inserter_thread: + { + insert_thread& inserter = static_cast( thr ); + nInsertSuccess += inserter.m_nInsertSuccess; + nInsertFailed += inserter.m_nInsertFailed; + nInsertInitSuccess += inserter.m_nInsertInitSuccess; + nInsertInitFailed += inserter.m_nInsertInitFailed; + } + break; + case deleter_thread: + { + delete_thread& deleter = static_cast( thr ); + nDeleteSuccess += deleter.m_nDeleteSuccess; + nDeleteFailed += deleter.m_nDeleteFailed; + } + break; + case find_thread: + { + observer_thread& observer = static_cast( thr ); + nFindEvenSuccess = observer.m_nFindEvenSuccess; + nFindEvenFailed = observer.m_nFindEvenFailed; + nFindOddSuccess = observer.m_nFindOddSuccess; + nFindOddFailed = observer.m_nFindOddFailed; + } + break; + } + } + + size_t const nInitialOddKeys = ( s_nMapSize * s_nInsThreadCount ) * 3 / 4; + + EXPECT_EQ( nInsertInitFailed, 0u ); + EXPECT_EQ( nInsertInitSuccess, s_nMapSize * s_nInsThreadCount ); + EXPECT_EQ( nFindEvenFailed, 0u ); + EXPECT_GE( nInsertSuccess + nInitialOddKeys, nDeleteSuccess ); + EXPECT_LE( nInsertSuccess, nDeleteSuccess ); + + propout() + << std::make_pair( "insert_init_success", nInsertInitSuccess ) + << std::make_pair( "insert_init_failed", nInsertInitFailed ) + << std::make_pair( "insert_success", nInsertSuccess ) + << std::make_pair( "insert_failed", nInsertFailed ) + << std::make_pair( "delete_success", nDeleteSuccess ) + << std::make_pair( "delete_failed", nDeleteFailed ) + << std::make_pair( "find_even_success", nFindEvenSuccess ) + << std::make_pair( "find_even_failed", nFindEvenFailed ) + << std::make_pair( "find_odd_success", nFindOddSuccess ) + << std::make_pair( "find_odd_failed", nFindOddFailed ); + + analyze( testMap ); + } + + template + void do_test_extract( Map& testMap ) + { + typedef Inserter insert_thread; + typedef Deleter delete_thread; + typedef Extractor< typename Map::gc, Map > extract_thread; + typedef Observer observer_thread; + + m_nInsThreadCount.store( s_nInsThreadCount, atomics::memory_order_release ); + + cds_test::thread_pool& pool = get_pool(); + pool.add( new insert_thread( pool, testMap ), s_nInsThreadCount ); + if ( s_nDelThreadCount ) + pool.add( new delete_thread( pool, testMap ), s_nDelThreadCount ); + if ( s_nExtractThreadCount ) + pool.add( new extract_thread( pool, testMap ), s_nExtractThreadCount ); + if ( s_nFindThreadCount ) + pool.add( new observer_thread( pool, testMap ), s_nFindThreadCount ); + + propout() << std::make_pair( "insert_thread_count", s_nInsThreadCount ) + << std::make_pair( "delete_thread_count", s_nDelThreadCount ) + << std::make_pair( "extract_thread_count", s_nExtractThreadCount ) + << std::make_pair( "find_thread_count", s_nFindThreadCount ) + << std::make_pair( "map_size", s_nMapSize ) + << std::make_pair( "pass_count", s_nInsertPassCount ); + + std::chrono::milliseconds duration = pool.run(); + + propout() << std::make_pair( "duration", duration ); + + size_t nInsertInitFailed = 0; + size_t nInsertInitSuccess = 0; + size_t nInsertSuccess = 0; + size_t nInsertFailed = 0; + size_t nDeleteSuccess = 0; + size_t nDeleteFailed = 0; + size_t nExtractSuccess = 0; + size_t nExtractFailed = 0; + + size_t nFindEvenSuccess = 0; + size_t nFindEvenFailed = 0; + size_t nFindOddSuccess = 0; + size_t nFindOddFailed = 0; + + for ( size_t i = 0; i < pool.size(); ++i ) { + cds_test::thread& thr = pool.get( i ); + switch ( thr.type()) { + case inserter_thread: + { + insert_thread& inserter = static_cast(thr); + nInsertSuccess += inserter.m_nInsertSuccess; + nInsertFailed += inserter.m_nInsertFailed; + nInsertInitSuccess += inserter.m_nInsertInitSuccess; + nInsertInitFailed += inserter.m_nInsertInitFailed; + } + break; + case deleter_thread: + { + delete_thread& deleter = static_cast(thr); + nDeleteSuccess += deleter.m_nDeleteSuccess; + nDeleteFailed += deleter.m_nDeleteFailed; + } + break; + case extractor_thread: + { + extract_thread& extractor = static_cast(thr); + nExtractSuccess += extractor.m_nDeleteSuccess; + nExtractFailed += extractor.m_nDeleteFailed; + } + break; + case find_thread: + { + observer_thread& observer = static_cast( thr ); + nFindEvenSuccess = observer.m_nFindEvenSuccess; + nFindEvenFailed = observer.m_nFindEvenFailed; + nFindOddSuccess = observer.m_nFindOddSuccess; + nFindOddFailed = observer.m_nFindOddFailed; + } + break; + default: + assert( false ); + } + } + + size_t const nInitialOddKeys = ( s_nMapSize * s_nInsThreadCount ) * 3 / 4; + + EXPECT_EQ( nInsertInitFailed, 0u ); + EXPECT_EQ( nInsertInitSuccess, s_nMapSize * s_nInsThreadCount ); + EXPECT_EQ( nFindEvenFailed, 0u ); + EXPECT_GE( nInsertSuccess + nInitialOddKeys, nDeleteSuccess + nExtractSuccess ); + EXPECT_LE( nInsertSuccess, nDeleteSuccess + nExtractSuccess ); + + propout() + << std::make_pair( "insert_init_success", nInsertInitSuccess ) + << std::make_pair( "insert_init_failed", nInsertInitFailed ) + << std::make_pair( "insert_success", nInsertSuccess ) + << std::make_pair( "insert_failed", nInsertFailed ) + << std::make_pair( "delete_success", nDeleteSuccess ) + << std::make_pair( "delete_failed", nDeleteFailed ) + << std::make_pair( "extract_success", nExtractSuccess ) + << std::make_pair( "extract_failed", nExtractFailed ) + << std::make_pair( "find_even_success", nFindEvenSuccess ) + << std::make_pair( "find_even_failed", nFindEvenFailed ) + << std::make_pair( "find_odd_success", nFindOddSuccess ) + << std::make_pair( "find_odd_failed", nFindOddFailed ); + + analyze( testMap ); + } + + template + void analyze( Map& testMap ) + { + // All even keys must be in the map + { + for ( size_t n = 0; n < s_nMapSize; n +=4 ) { + for ( size_t i = 0; i < s_nInsThreadCount; ++i ) { + EXPECT_TRUE( testMap.contains( key_type( n, i ))) << "key=" << n << "/" << i; + } + } + } + + print_stat( propout(), testMap ); + + check_before_cleanup( testMap ); + testMap.clear(); + EXPECT_TRUE( testMap.empty()) << "map.size=" << testMap.size(); + + additional_check( testMap ); + additional_cleanup( testMap ); + } + + template + void run_test_extract() + { + static_assert( Map::c_bExtractSupported, "Map class must support extract() method" ); + + size_t nMapSize = s_nMapSize; + s_nMapSize *= s_nInsThreadCount; + + Map testMap( *this ); + + s_nMapSize = nMapSize; + do_test_extract( testMap ); + } + + template + void run_test() + { + size_t nMapSize = s_nMapSize; + s_nMapSize *= s_nInsThreadCount; + + Map testMap( *this ); + + s_nMapSize = nMapSize; + do_test( testMap ); + } + + template + void run_feldman(); + }; + + class Map_Del3_LF: public Map_Del3 + , public ::testing::WithParamInterface + { + public: + template + void run_test() + { + s_nLoadFactor = GetParam(); + propout() << std::make_pair( "load_factor", s_nLoadFactor ); + Map_Del3::run_test(); + } + + template + void run_test_extract() + { + s_nLoadFactor = GetParam(); + propout() << std::make_pair( "load_factor", s_nLoadFactor ); + Map_Del3::run_test_extract(); + } + + static std::vector get_load_factors(); + }; + +} // namespace map diff --git a/test/stress/map/insdel_int/map_insdel_int_bronsonavltree.cpp b/test/stress/map/del3/map_del3_bronsonavltree.cpp similarity index 94% rename from test/stress/map/insdel_int/map_insdel_int_bronsonavltree.cpp rename to test/stress/map/del3/map_del3_bronsonavltree.cpp index b28326d1..d517aa13 100644 --- a/test/stress/map/insdel_int/map_insdel_int_bronsonavltree.cpp +++ b/test/stress/map/del3/map_del3_bronsonavltree.cpp @@ -28,11 +28,11 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_insdel_int.h" +#include "map_del3.h" #include "map_type_bronson_avltree.h" namespace map { - CDSSTRESS_BronsonAVLTreeMap( Map_InsDel_int, run_test, size_t, size_t ) + CDSSTRESS_BronsonAVLTreeMap( Map_Del3, run_test_extract, key_thread, size_t ) } // namespace map diff --git a/test/stress/map/insdel_int/map_insdel_int_cuckoo.cpp b/test/stress/map/del3/map_del3_cuckoo.cpp similarity index 94% rename from test/stress/map/insdel_int/map_insdel_int_cuckoo.cpp rename to test/stress/map/del3/map_del3_cuckoo.cpp index a3af5a65..208e8af5 100644 --- a/test/stress/map/insdel_int/map_insdel_int_cuckoo.cpp +++ b/test/stress/map/del3/map_del3_cuckoo.cpp @@ -28,11 +28,11 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_insdel_int.h" +#include "map_del3.h" #include "map_type_cuckoo.h" namespace map { - CDSSTRESS_CuckooMap( Map_InsDel_int, run_test, size_t, size_t ) + CDSSTRESS_CuckooMap( Map_Del3, run_test, key_thread, size_t ) } // namespace map diff --git a/test/stress/map/insdel_int/map_insdel_int_ellentree.cpp b/test/stress/map/del3/map_del3_ellentree.cpp similarity index 94% rename from test/stress/map/insdel_int/map_insdel_int_ellentree.cpp rename to test/stress/map/del3/map_del3_ellentree.cpp index 231494b0..6cffc105 100644 --- a/test/stress/map/insdel_int/map_insdel_int_ellentree.cpp +++ b/test/stress/map/del3/map_del3_ellentree.cpp @@ -28,11 +28,11 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_insdel_int.h" +#include "map_del3.h" #include "map_type_ellen_bintree.h" namespace map { - CDSSTRESS_EllenBinTreeMap( Map_InsDel_int, run_test, size_t, size_t ) + CDSSTRESS_EllenBinTreeMap( Map_Del3, run_test_extract, key_thread, size_t ) } // namespace map diff --git a/test/stress/map/insdel_int/map_insdel_int_feldman_hashset.cpp b/test/stress/map/del3/map_del3_feldman_hashmap.cpp similarity index 77% rename from test/stress/map/insdel_int/map_insdel_int_feldman_hashset.cpp rename to test/stress/map/del3/map_del3_feldman_hashmap.cpp index 144e2e47..6ed2726a 100644 --- a/test/stress/map/insdel_int/map_insdel_int_feldman_hashset.cpp +++ b/test/stress/map/del3/map_del3_feldman_hashmap.cpp @@ -28,11 +28,23 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_insdel_int.h" +#include "map_del3.h" #include "map_type_feldman_hashmap.h" namespace map { - CDSSTRESS_FeldmanHashMap_fixed( Map_InsDel_int, run_test, size_t, size_t ) + template + void Map_Del3::run_feldman() + { + typedef typename Map::traits original_traits; + struct traits: public original_traits { + enum { hash_size = sizeof( uint32_t ) + sizeof( uint16_t ) }; + }; + typedef typename Map::template rebind_traits< traits >::result map_type; + + run_test_extract(); + } + + CDSSTRESS_FeldmanHashMap_fixed( Map_Del3, run_feldman, key_thread, size_t ) } // namespace map diff --git a/test/stress/map/insdel_int/map_insdel_int_michael.cpp b/test/stress/map/del3/map_del3_michael.cpp similarity index 94% rename from test/stress/map/insdel_int/map_insdel_int_michael.cpp rename to test/stress/map/del3/map_del3_michael.cpp index d5b222fd..4c3173b0 100644 --- a/test/stress/map/insdel_int/map_insdel_int_michael.cpp +++ b/test/stress/map/del3/map_del3_michael.cpp @@ -28,11 +28,11 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_insdel_int.h" +#include "map_del3.h" #include "map_type_michael.h" namespace map { - CDSSTRESS_MichaelMap( Map_InsDel_int_LF, run_test, size_t, size_t ) + CDSSTRESS_MichaelMap( Map_Del3_LF, run_test_extract, key_thread, size_t ) } // namespace map diff --git a/test/stress/map/insdel_int/map_insdel_int_skip.cpp b/test/stress/map/del3/map_del3_skip.cpp similarity index 94% rename from test/stress/map/insdel_int/map_insdel_int_skip.cpp rename to test/stress/map/del3/map_del3_skip.cpp index f6ef14ca..210b965b 100644 --- a/test/stress/map/insdel_int/map_insdel_int_skip.cpp +++ b/test/stress/map/del3/map_del3_skip.cpp @@ -28,11 +28,11 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_insdel_int.h" +#include "map_del3.h" #include "map_type_skip_list.h" namespace map { - CDSSTRESS_SkipListMap( Map_InsDel_int, run_test, size_t, size_t ) + CDSSTRESS_SkipListMap( Map_Del3, run_test_extract, key_thread, size_t ) } // namespace map diff --git a/test/stress/map/insdel_int/map_insdel_int_split.cpp b/test/stress/map/del3/map_del3_split.cpp similarity index 89% rename from test/stress/map/insdel_int/map_insdel_int_split.cpp rename to test/stress/map/del3/map_del3_split.cpp index 14098680..a64ec5a9 100644 --- a/test/stress/map/insdel_int/map_insdel_int_split.cpp +++ b/test/stress/map/del3/map_del3_split.cpp @@ -28,12 +28,12 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_insdel_int.h" +#include "map_del3.h" #include "map_type_split_list.h" namespace map { - CDSSTRESS_SplitListMap( Map_InsDel_int_LF, run_test, size_t, size_t ) - CDSSTRESS_SplitListIterableMap( Map_InsDel_int_LF, run_test, size_t, size_t ) + CDSSTRESS_SplitListMap( Map_Del3_LF, run_test_extract, key_thread, size_t ) + CDSSTRESS_SplitListIterableMap( Map_Del3_LF, run_test_extract, key_thread, size_t ) } // namespace map diff --git a/test/stress/map/find_int/CMakeLists.txt b/test/stress/map/find_int/CMakeLists.txt deleted file mode 100644 index 3ec07cea..00000000 --- a/test/stress/map/find_int/CMakeLists.txt +++ /dev/null @@ -1,31 +0,0 @@ -set(PACKAGE_NAME stress-map-find-int) - -set(CDSSTRESS_MAP_FIND_INT_SOURCES - ../../main.cpp - map_find_int.cpp - map_find_int_bronsonavltree.cpp - map_find_int_cuckoo.cpp - map_find_int_ellentree.cpp - map_find_int_feldman_hashset.cpp - map_find_int_michael.cpp - map_find_int_skip.cpp - map_find_int_split.cpp - map_find_int_std.cpp - map_find_int_striped.cpp -) - -include_directories( - ${CMAKE_CURRENT_SOURCE_DIR} - ${CMAKE_CURRENT_SOURCE_DIR}/.. -) - -add_executable(${PACKAGE_NAME} ${CDSSTRESS_MAP_FIND_INT_SOURCES} $) -target_link_libraries(${PACKAGE_NAME} - ${CDS_SHARED_LIBRARY} - ${GTEST_LIBRARY} - ${Boost_THREAD_LIBRARY} - ${Boost_SYSTEM_LIBRARY} - ${CMAKE_THREAD_LIBS_INIT} -) - -add_test(NAME ${PACKAGE_NAME} COMMAND ${PACKAGE_NAME} WORKING_DIRECTORY ${EXECUTABLE_OUTPUT_PATH}) \ No newline at end of file diff --git a/test/stress/map/find_int/map_find_int.h b/test/stress/map/find_int/map_find_int.h deleted file mode 100644 index 7ea84980..00000000 --- a/test/stress/map/find_int/map_find_int.h +++ /dev/null @@ -1,244 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_type.h" - -// find int test in map in mutithreaded mode -namespace map { - - class Map_find_int: public cds_test::stress_fixture - { - public: - static size_t s_nThreadCount; // thread count - static size_t s_nMapSize; // map size (count of searching item) - static size_t s_nPercentExists; // percent of existing keys in searching sequence - static size_t s_nPassCount; - static size_t s_nMaxLoadFactor; // maximum load factor - - static size_t s_nCuckooInitialSize; // initial size for CuckooMap - static size_t s_nCuckooProbesetSize; // CuckooMap probeset size (only for list-based probeset) - static size_t s_nCuckooProbesetThreshold; // CUckooMap probeset threshold (o - use default) - - static size_t s_nFeldmanMap_HeadBits; - static size_t s_nFeldmanMap_ArrayBits; - - static size_t s_nLoadFactor; // current load factor - - typedef size_t key_type; - struct value_type { - key_type nKey; // key - bool bExists; // true - key in map, false - key not in map - }; - - typedef std::vector value_vector; - static value_vector s_Data; - - static void SetUpTestCase(); - static void TearDownTestCase(); - - private: - static size_t s_nRealMapSize; - - static void generateSequence(); - - template - static bool check_result( Iterator const& it, Map const& map ) - { - return it != map.end(); - } - template - static bool check_result( bool b, Map const& ) - { - return b; - } - - template - class Worker: public cds_test::thread - { - typedef cds_test::thread base_class; - Map& m_Map; - - public: - struct Stat { - size_t nSuccess = 0; - size_t nFailed = 0; - }; - - Stat m_KeyExists; - Stat m_KeyNotExists; - - public: - Worker( cds_test::thread_pool& pool, Map& map ) - : base_class( pool ) - , m_Map( map ) - , m_KeyExists() - , m_KeyNotExists() - {} - - Worker( Worker& src ) - : base_class( src ) - , m_Map( src.m_Map ) - , m_KeyExists() - , m_KeyNotExists() - {} - - virtual thread * clone() - { - return new Worker( *this ); - } - - virtual void test() - { - size_t const nPassCount = s_nPassCount; - - Map& rMap = m_Map; - for ( size_t nPass = 0; nPass < nPassCount; ++nPass ) { - if ( id() & 1 ) { - auto itEnd = s_Data.cend(); - for ( auto it = s_Data.cbegin(); it != itEnd; ++it ) { - auto bFound = rMap.contains( it->nKey ); - if ( it->bExists ) { - if ( check_result( bFound, rMap )) - ++m_KeyExists.nSuccess; - else - ++m_KeyExists.nFailed; - } - else { - if ( check_result( bFound, rMap )) - ++m_KeyNotExists.nFailed; - else - ++m_KeyNotExists.nSuccess; - } - } - } - else { - auto itEnd = s_Data.crend(); - for ( auto it = s_Data.crbegin(); it != itEnd; ++it ) { - auto bFound = rMap.contains( it->nKey ); - if ( it->bExists ) { - if ( check_result( bFound, rMap )) - ++m_KeyExists.nSuccess; - else - ++m_KeyExists.nFailed; - } - else { - if ( check_result( bFound, rMap )) - ++m_KeyNotExists.nFailed; - else - ++m_KeyNotExists.nSuccess; - } - } - } - } - } - }; - - protected: - - template - void test( Map& testMap ) - { - typedef Worker worker; - - // Fill the map - for ( auto const& it: s_Data ) { - if ( it.bExists ) { - EXPECT_TRUE( check_result( testMap.insert( it.nKey, it ), testMap )); - } - } - - propout() << std::make_pair( "thread_count", s_nThreadCount ) - << std::make_pair( "map_size", s_nMapSize ) - << std::make_pair( "percent_exist", s_nPercentExists ) - << std::make_pair( "pass_count", s_nPassCount ); - - cds_test::thread_pool& pool = get_pool(); - pool.add( new worker( pool, testMap ), s_nThreadCount ); - - std::chrono::milliseconds duration = pool.run(); - - propout() << std::make_pair( "duration", duration ); - - size_t nExistSuccess = 0; - size_t nExistFailed = 0; - size_t nMissingSuccess = 0; - size_t nMissingFailed = 0; - - for ( size_t i = 0; i < pool.size(); ++i ) { - worker& w = static_cast( pool.get( i )); - nExistSuccess += w.m_KeyExists.nSuccess; - nExistFailed += w.m_KeyExists.nFailed; - nMissingSuccess += w.m_KeyNotExists.nSuccess; - nMissingFailed += w.m_KeyNotExists.nFailed; - - EXPECT_EQ( w.m_KeyExists.nFailed, 0u ) << "thread " << i; - EXPECT_EQ( w.m_KeyExists.nSuccess, s_nRealMapSize * s_nPassCount ) << "thread " << i; - EXPECT_EQ( w.m_KeyNotExists.nFailed, 0u ) << "thread " << i; - EXPECT_EQ( w.m_KeyNotExists.nSuccess, (s_Data.size() - s_nRealMapSize) * s_nPassCount ) << "thread " << i; - } - - propout() - << std::make_pair( "exist_found", nExistSuccess ) - << std::make_pair( "exist_not_found", nExistFailed ) // must = 0 - << std::make_pair( "missing_not_found", nMissingSuccess ) - << std::make_pair( "missing_found", nMissingFailed ); // must = 0 - - check_before_cleanup( testMap ); - - testMap.clear(); - additional_check( testMap ); - print_stat( propout(), testMap ); - additional_cleanup( testMap ); - } - - template - void run_test() - { - Map testMap( *this ); - test( testMap ); - } - }; - - class Map_find_int_LF: public Map_find_int - , public ::testing::WithParamInterface - { - public: - template - void run_test() - { - s_nLoadFactor = GetParam(); - propout() << std::make_pair( "load_factor", s_nLoadFactor ); - Map_find_int::run_test(); - } - - static std::vector get_load_factors(); - }; - -} // namespace map diff --git a/test/stress/map/find_int/map_find_int_feldman_hashset.cpp b/test/stress/map/find_int/map_find_int_feldman_hashset.cpp deleted file mode 100644 index 311e67da..00000000 --- a/test/stress/map/find_int/map_find_int_feldman_hashset.cpp +++ /dev/null @@ -1,38 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_find_int.h" -#include "map_type_feldman_hashmap.h" - -namespace map { - - CDSSTRESS_FeldmanHashMap_fixed( Map_find_int, run_test, size_t, Map_find_int::value_type ) - -} // namespace map diff --git a/test/stress/map/find_int/map_find_int_michael.cpp b/test/stress/map/find_int/map_find_int_michael.cpp deleted file mode 100644 index 05317c54..00000000 --- a/test/stress/map/find_int/map_find_int_michael.cpp +++ /dev/null @@ -1,39 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_find_int.h" -#include "map_type_michael.h" - -namespace map { - - CDSSTRESS_MichaelMap( Map_find_int_LF, run_test, size_t, Map_find_int::value_type ) - CDSSTRESS_MichaelMap_nogc( Map_find_int_LF, run_test, size_t, Map_find_int::value_type ) - -} // namespace map diff --git a/test/stress/map/find_int/map_find_int_skip.cpp b/test/stress/map/find_int/map_find_int_skip.cpp deleted file mode 100644 index 8aac30b7..00000000 --- a/test/stress/map/find_int/map_find_int_skip.cpp +++ /dev/null @@ -1,39 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_find_int.h" -#include "map_type_skip_list.h" - -namespace map { - - CDSSTRESS_SkipListMap( Map_find_int, run_test, size_t, Map_find_int::value_type ) - CDSSTRESS_SkipListMap_nogc( Map_find_int, run_test, size_t, Map_find_int::value_type ) - -} // namespace map diff --git a/test/stress/map/find_int/map_find_int_split.cpp b/test/stress/map/find_int/map_find_int_split.cpp deleted file mode 100644 index bbbe1d1f..00000000 --- a/test/stress/map/find_int/map_find_int_split.cpp +++ /dev/null @@ -1,40 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_find_int.h" -#include "map_type_split_list.h" - -namespace map { - - CDSSTRESS_SplitListMap( Map_find_int_LF, run_test, size_t, Map_find_int::value_type ) - CDSSTRESS_SplitListIterableMap( Map_find_int_LF, run_test, size_t, Map_find_int::value_type ) - CDSSTRESS_SplitListMap_nogc( Map_find_int_LF, run_test, size_t, Map_find_int::value_type ) - -} // namespace map diff --git a/test/stress/map/find_int/map_find_int_std.cpp b/test/stress/map/find_int/map_find_int_std.cpp deleted file mode 100644 index 94307d64..00000000 --- a/test/stress/map/find_int/map_find_int_std.cpp +++ /dev/null @@ -1,39 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_find_int.h" -#include "map_type_std.h" - -namespace map { - - CDSSTRESS_StdMap( Map_find_int, run_test, size_t, Map_find_int::value_type ) - CDSSTRESS_StdMap_nolock( Map_find_int, run_test, size_t, Map_find_int::value_type ) - -} // namespace map diff --git a/test/stress/map/find_int/map_find_int_striped.cpp b/test/stress/map/find_int/map_find_int_striped.cpp deleted file mode 100644 index e4a462ce..00000000 --- a/test/stress/map/find_int/map_find_int_striped.cpp +++ /dev/null @@ -1,38 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_find_int.h" -#include "map_type_striped.h" - -namespace map { - - CDSSTRESS_StripedMap( Map_find_int_LF, run_test, size_t, Map_find_int::value_type ) - -} // namespace map diff --git a/test/stress/map/insdel_int/CMakeLists.txt b/test/stress/map/insdel_int/CMakeLists.txt deleted file mode 100644 index 7c23b0cf..00000000 --- a/test/stress/map/insdel_int/CMakeLists.txt +++ /dev/null @@ -1,31 +0,0 @@ -set(PACKAGE_NAME stress-map-insdel-int) - -set(CDSSTRESS_MAP_INSDEL_INT_SOURCES - ../../main.cpp - map_insdel_int.cpp - map_insdel_int_bronsonavltree.cpp - map_insdel_int_cuckoo.cpp - map_insdel_int_ellentree.cpp - map_insdel_int_feldman_hashset.cpp - map_insdel_int_michael.cpp - map_insdel_int_skip.cpp - map_insdel_int_split.cpp - map_insdel_int_std.cpp - map_insdel_int_striped.cpp -) - -include_directories( - ${CMAKE_CURRENT_SOURCE_DIR} - ${CMAKE_CURRENT_SOURCE_DIR}/.. -) - -add_executable(${PACKAGE_NAME} ${CDSSTRESS_MAP_INSDEL_INT_SOURCES} $) -target_link_libraries(${PACKAGE_NAME} - ${CDS_SHARED_LIBRARY} - ${GTEST_LIBRARY} - ${Boost_THREAD_LIBRARY} - ${Boost_SYSTEM_LIBRARY} - ${CMAKE_THREAD_LIBS_INIT} -) - -add_test(NAME ${PACKAGE_NAME} COMMAND ${PACKAGE_NAME} WORKING_DIRECTORY ${EXECUTABLE_OUTPUT_PATH}) \ No newline at end of file diff --git a/test/stress/map/insdel_int/map_insdel_int.cpp b/test/stress/map/insdel_int/map_insdel_int.cpp deleted file mode 100644 index 09117613..00000000 --- a/test/stress/map/insdel_int/map_insdel_int.cpp +++ /dev/null @@ -1,121 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_insdel_int.h" - -namespace map { - - size_t Map_InsDel_int::s_nMapSize = 1000000; // map size - size_t Map_InsDel_int::s_nInsertThreadCount = 4; // count of insertion thread - size_t Map_InsDel_int::s_nDeleteThreadCount = 4; // count of deletion thread - size_t Map_InsDel_int::s_nThreadPassCount = 4; // pass count for each thread - size_t Map_InsDel_int::s_nMaxLoadFactor = 8; // maximum load factor - - size_t Map_InsDel_int::s_nCuckooInitialSize = 1024;// initial size for CuckooSet - size_t Map_InsDel_int::s_nCuckooProbesetSize = 16; // CuckooSet probeset size (only for list-based probeset) - size_t Map_InsDel_int::s_nCuckooProbesetThreshold = 0; // CUckooSet probeset threshold (0 - use default) - - size_t Map_InsDel_int::s_nFeldmanMap_HeadBits = 10; - size_t Map_InsDel_int::s_nFeldmanMap_ArrayBits = 4; - - size_t Map_InsDel_int::s_nLoadFactor = 1; - Map_InsDel_int::key_array Map_InsDel_int::s_arrKeys; - - void Map_InsDel_int::SetUpTestCase() - { - cds_test::config const& cfg = get_config( "map_insdel_int" ); - - s_nMapSize = cfg.get_size_t( "MapSize", s_nMapSize ); - if ( s_nMapSize < 1000 ) - s_nMapSize = 1000; - - s_nInsertThreadCount = cfg.get_size_t( "InsertThreadCount", s_nInsertThreadCount ); - if ( s_nInsertThreadCount == 0 ) - s_nInsertThreadCount = 2; - - s_nDeleteThreadCount = cfg.get_size_t( "DeleteThreadCount", s_nDeleteThreadCount ); - if ( s_nDeleteThreadCount == 0 ) - s_nDeleteThreadCount = 2; - - s_nThreadPassCount = cfg.get_size_t( "ThreadPassCount", s_nThreadPassCount ); - if ( s_nThreadPassCount == 0 ) - s_nThreadPassCount = 4; - - s_nMaxLoadFactor = cfg.get_size_t( "MaxLoadFactor", s_nMaxLoadFactor ); - if ( s_nMaxLoadFactor == 0 ) - s_nMaxLoadFactor = 1; - - s_nCuckooInitialSize = cfg.get_size_t( "CuckooInitialSize", s_nCuckooInitialSize ); - if ( s_nCuckooInitialSize < 256 ) - s_nCuckooInitialSize = 256; - - s_nCuckooProbesetSize = cfg.get_size_t( "CuckooProbesetSize", s_nCuckooProbesetSize ); - if ( s_nCuckooProbesetSize < 8 ) - s_nCuckooProbesetSize = 8; - - s_nCuckooProbesetThreshold = cfg.get_size_t( "CuckooProbesetThreshold", s_nCuckooProbesetThreshold ); - - s_nFeldmanMap_HeadBits = cfg.get_size_t( "FeldmanMapHeadBits", s_nFeldmanMap_HeadBits ); - if ( s_nFeldmanMap_HeadBits == 0 ) - s_nFeldmanMap_HeadBits = 2; - - s_nFeldmanMap_ArrayBits = cfg.get_size_t( "FeldmanMapArrayBits", s_nFeldmanMap_ArrayBits ); - if ( s_nFeldmanMap_ArrayBits == 0 ) - s_nFeldmanMap_ArrayBits = 2; - - s_arrKeys.clear(); - s_arrKeys.reserve( s_nMapSize ); - for ( size_t i = 0; i < s_nMapSize; ++i ) - s_arrKeys.push_back( i ); - shuffle( s_arrKeys.begin(), s_arrKeys.end()); - } - - void Map_InsDel_int::TearDownTestCase() - { - s_arrKeys.clear(); - } - - std::vector Map_InsDel_int_LF::get_load_factors() - { - cds_test::config const& cfg = get_config( "map_insdel_int" ); - - s_nMaxLoadFactor = cfg.get_size_t( "MaxLoadFactor", s_nMaxLoadFactor ); - if ( s_nMaxLoadFactor == 0 ) - s_nMaxLoadFactor = 1; - - std::vector lf; - for ( size_t n = 1; n <= s_nMaxLoadFactor; n *= 2 ) - lf.push_back( n ); - - return lf; - } - - INSTANTIATE_TEST_CASE_P( a, Map_InsDel_int_LF, ::testing::ValuesIn( Map_InsDel_int_LF::get_load_factors())); -} // namespace map diff --git a/test/stress/map/insdel_int/map_insdel_int.h b/test/stress/map/insdel_int/map_insdel_int.h deleted file mode 100644 index d757021c..00000000 --- a/test/stress/map/insdel_int/map_insdel_int.h +++ /dev/null @@ -1,261 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_type.h" - -namespace map { - - class Map_InsDel_int: public cds_test::stress_fixture - { - public: - static size_t s_nMapSize; // map size - static size_t s_nInsertThreadCount; // count of insertion thread - static size_t s_nDeleteThreadCount; // count of deletion thread - static size_t s_nThreadPassCount; // pass count for each thread - static size_t s_nMaxLoadFactor; // maximum load factor - - static size_t s_nCuckooInitialSize; // initial size for CuckooMap - static size_t s_nCuckooProbesetSize; // CuckooMap probeset size (only for list-based probeset) - static size_t s_nCuckooProbesetThreshold; // CuckooMap probeset threshold (o - use default) - - static size_t s_nFeldmanMap_HeadBits; - static size_t s_nFeldmanMap_ArrayBits; - - static size_t s_nLoadFactor; // current load factor - - static void SetUpTestCase(); - static void TearDownTestCase(); - - typedef size_t key_type; - typedef size_t value_type; - - typedef std::vector key_array; - static key_array s_arrKeys; - - protected: - enum { - insert_thread, - delete_thread - }; - - template - class Inserter: public cds_test::thread - { - typedef cds_test::thread base_class; - Map& m_Map; - - public: - size_t m_nInsertSuccess = 0; - size_t m_nInsertFailed = 0; - - public: - Inserter( cds_test::thread_pool& pool, Map& map ) - : base_class( pool, insert_thread ) - , m_Map( map ) - {} - - Inserter( Inserter& src ) - : base_class( src ) - , m_Map( src.m_Map ) - {} - - virtual thread * clone() - { - return new Inserter( *this ); - } - - virtual void test() - { - Map& rMap = m_Map; - - if ( id() & 1 ) { - for ( size_t nPass = 0; nPass < s_nThreadPassCount; ++nPass ) { - for ( key_array::const_iterator it = s_arrKeys.cbegin(), itEnd = s_arrKeys.cend(); it != itEnd; ++it ) { - if ( rMap.insert( *it, *it * 8 )) - ++m_nInsertSuccess; - else - ++m_nInsertFailed; - } - } - } - else { - for ( size_t nPass = 0; nPass < s_nThreadPassCount; ++nPass ) { - for ( key_array::const_reverse_iterator it = s_arrKeys.crbegin(), itEnd = s_arrKeys.crend(); it != itEnd; ++it ) { - if ( rMap.insert( *it, *it * 8 )) - ++m_nInsertSuccess; - else - ++m_nInsertFailed; - } - } - } - } - }; - - template - class Deleter: public cds_test::thread - { - typedef cds_test::thread base_class; - Map& m_Map; - public: - size_t m_nDeleteSuccess = 0; - size_t m_nDeleteFailed = 0; - - public: - Deleter( cds_test::thread_pool& pool, Map& map ) - : base_class( pool, delete_thread ) - , m_Map( map ) - {} - - Deleter( Deleter& src ) - : base_class( src ) - , m_Map( src.m_Map ) - {} - - virtual thread * clone() - { - return new Deleter( *this ); - } - - virtual void test() - { - Map& rMap = m_Map; - - if ( id() & 1 ) { - for ( size_t nPass = 0; nPass < s_nThreadPassCount; ++nPass ) { - for ( key_array::const_iterator it = s_arrKeys.cbegin(), itEnd = s_arrKeys.cend(); it != itEnd; ++it ) { - if ( rMap.erase( *it )) - ++m_nDeleteSuccess; - else - ++m_nDeleteFailed; - } - } - } - else { - for ( size_t nPass = 0; nPass < s_nThreadPassCount; ++nPass ) { - for ( key_array::const_reverse_iterator it = s_arrKeys.crbegin(), itEnd = s_arrKeys.crend(); it != itEnd; ++it ) { - if ( rMap.erase( *it )) - ++m_nDeleteSuccess; - else - ++m_nDeleteFailed; - } - } - } - } - }; - - protected: - template - void do_test( Map& testMap ) - { - typedef Inserter inserter; - typedef Deleter deleter; - - cds_test::thread_pool& pool = get_pool(); - pool.add( new inserter( pool, testMap ), s_nInsertThreadCount ); - pool.add( new deleter( pool, testMap ), s_nDeleteThreadCount ); - - propout() << std::make_pair( "insert_thread_count", s_nInsertThreadCount ) - << std::make_pair( "delete_thread_count", s_nDeleteThreadCount ) - << std::make_pair( "pass_count", s_nThreadPassCount ) - << std::make_pair( "map_size", s_nMapSize ); - - std::chrono::milliseconds duration = pool.run(); - - propout() << std::make_pair( "duration", duration ); - - size_t nInsertSuccess = 0; - size_t nInsertFailed = 0; - size_t nDeleteSuccess = 0; - size_t nDeleteFailed = 0; - - for ( size_t i = 0; i < pool.size(); ++i ) { - cds_test::thread& thr = pool.get( i ); - switch ( thr.type()) { - case insert_thread: - { - inserter& t = static_cast( thr ); - nInsertSuccess += t.m_nInsertSuccess; - nInsertFailed += t.m_nInsertFailed; - } - break; - case delete_thread: - { - deleter& t = static_cast(thr); - nDeleteSuccess += t.m_nDeleteSuccess; - nDeleteFailed += t.m_nDeleteFailed; - } - break; - default: - assert( false ); - } - } - - propout() - << std::make_pair( "insert_success", nInsertSuccess ) - << std::make_pair( "insert_failed", nInsertFailed ) - << std::make_pair( "delete_success", nDeleteSuccess ) - << std::make_pair( "delete_failed", nDeleteFailed ) - << std::make_pair( "finish_map_size", testMap.size()); - - check_before_cleanup( testMap ); - - testMap.clear(); - - EXPECT_TRUE( testMap.empty()); - - additional_check( testMap ); - print_stat( propout(), testMap ); - additional_cleanup( testMap ); - } - - template - void run_test() - { - Map testMap( *this ); - do_test( testMap ); - } - }; - - class Map_InsDel_int_LF: public Map_InsDel_int - , public ::testing::WithParamInterface - { - public: - template - void run_test() - { - s_nLoadFactor = GetParam(); - propout() << std::make_pair( "load_factor", s_nLoadFactor ); - Map_InsDel_int::run_test(); - } - - static std::vector get_load_factors(); - }; - -} // namespace map diff --git a/test/stress/map/insdel_int/map_insdel_int_striped.cpp b/test/stress/map/insdel_int/map_insdel_int_striped.cpp deleted file mode 100644 index 1c72b5a8..00000000 --- a/test/stress/map/insdel_int/map_insdel_int_striped.cpp +++ /dev/null @@ -1,38 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_insdel_int.h" -#include "map_type_striped.h" - -namespace map { - - CDSSTRESS_StripedMap( Map_InsDel_int_LF, run_test, size_t, size_t ) - -} // namespace map diff --git a/test/stress/map/insfind_int/CMakeLists.txt b/test/stress/map/insfind_int/CMakeLists.txt deleted file mode 100644 index 9027a4b0..00000000 --- a/test/stress/map/insfind_int/CMakeLists.txt +++ /dev/null @@ -1,31 +0,0 @@ -set(PACKAGE_NAME stress-map-insfind-int) - -set(CDSSTRESS_MAP_INSFIND_INT_SOURCES - ../../main.cpp - map_insfind.cpp - map_insfind_bronsonavltree.cpp - map_insfind_cuckoo.cpp - map_insfind_ellentree.cpp - map_insfind_feldman_hashset.cpp - map_insfind_michael.cpp - map_insfind_skip.cpp - map_insfind_split.cpp - map_insfind_std.cpp - map_insfind_striped.cpp -) - -include_directories( - ${CMAKE_CURRENT_SOURCE_DIR} - ${CMAKE_CURRENT_SOURCE_DIR}/.. -) - -add_executable(${PACKAGE_NAME} ${CDSSTRESS_MAP_INSFIND_INT_SOURCES} $) -target_link_libraries(${PACKAGE_NAME} - ${CDS_SHARED_LIBRARY} - ${GTEST_LIBRARY} - ${Boost_THREAD_LIBRARY} - ${Boost_SYSTEM_LIBRARY} - ${CMAKE_THREAD_LIBS_INIT} -) - -add_test(NAME ${PACKAGE_NAME} COMMAND ${PACKAGE_NAME} WORKING_DIRECTORY ${EXECUTABLE_OUTPUT_PATH}) \ No newline at end of file diff --git a/test/stress/map/insfind_int/map_insfind_bronsonavltree.cpp b/test/stress/map/insfind_int/map_insfind_bronsonavltree.cpp deleted file mode 100644 index 4c3902a4..00000000 --- a/test/stress/map/insfind_int/map_insfind_bronsonavltree.cpp +++ /dev/null @@ -1,38 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_insfind_int.h" -#include "map_type_bronson_avltree.h" - -namespace map { - - CDSSTRESS_BronsonAVLTreeMap( Map_InsFind_int, run_test, size_t, size_t ) - -} // namespace map diff --git a/test/stress/map/insfind_int/map_insfind_cuckoo.cpp b/test/stress/map/insfind_int/map_insfind_cuckoo.cpp deleted file mode 100644 index 889b0de3..00000000 --- a/test/stress/map/insfind_int/map_insfind_cuckoo.cpp +++ /dev/null @@ -1,38 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_insfind_int.h" -#include "map_type_cuckoo.h" - -namespace map { - - CDSSTRESS_CuckooMap( Map_InsFind_int, run_test, size_t, size_t ) - -} // namespace map diff --git a/test/stress/map/insfind_int/map_insfind_ellentree.cpp b/test/stress/map/insfind_int/map_insfind_ellentree.cpp deleted file mode 100644 index 9cf34a62..00000000 --- a/test/stress/map/insfind_int/map_insfind_ellentree.cpp +++ /dev/null @@ -1,38 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_insfind_int.h" -#include "map_type_ellen_bintree.h" - -namespace map { - - CDSSTRESS_EllenBinTreeMap( Map_InsFind_int, run_test, size_t, size_t ) - -} // namespace map diff --git a/test/stress/map/insfind_int/map_insfind_feldman_hashset.cpp b/test/stress/map/insfind_int/map_insfind_feldman_hashset.cpp deleted file mode 100644 index e830b467..00000000 --- a/test/stress/map/insfind_int/map_insfind_feldman_hashset.cpp +++ /dev/null @@ -1,38 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_insfind_int.h" -#include "map_type_feldman_hashmap.h" - -namespace map { - - CDSSTRESS_FeldmanHashMap_fixed( Map_InsFind_int, run_test, size_t, size_t ) - -} // namespace map diff --git a/test/stress/map/insfind_int/map_insfind_int.h b/test/stress/map/insfind_int/map_insfind_int.h deleted file mode 100644 index f7a09774..00000000 --- a/test/stress/map/insfind_int/map_insfind_int.h +++ /dev/null @@ -1,210 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_type.h" - -namespace map { - - class Map_InsFind_int: public cds_test::stress_fixture - { - public: - static size_t s_nMapSize; // initial map size - static size_t s_nThreadCount; // thread count - static size_t s_nMaxLoadFactor; // maximum load factor - - static size_t s_nCuckooInitialSize; // initial size for CuckooMap - static size_t s_nCuckooProbesetSize; // CuckooMap probeset size (only for list-based probeset) - static size_t s_nCuckooProbesetThreshold; // CuckooMap probeset threshold (o - use default) - - static size_t s_nFeldmanMap_HeadBits; - static size_t s_nFeldmanMap_ArrayBits; - - static size_t s_nLoadFactor; // current load factor - - static void SetUpTestCase(); - //static void TearDownTestCase(); - - private: - typedef size_t key_type; - typedef size_t value_type; - - template - static bool check_result( Iterator const& it, Map const& map ) - { - return it != map.end(); - } - template - static bool check_result( bool b, Map const& ) - { - return b; - } - - template - class Inserter: public cds_test::thread - { - typedef cds_test::thread base_class; - - Map& m_Map; - std::vector m_arrVal; - - void make_array() - { - size_t const nThreadCount = s_nThreadCount; - size_t const nSize = s_nMapSize / nThreadCount + 1; - m_arrVal.resize( nSize ); - size_t nItem = id(); - for ( size_t i = 0; i < nSize; nItem += nThreadCount, ++i ) - m_arrVal[i] = nItem; - shuffle( m_arrVal.begin(), m_arrVal.end()); - } - public: - size_t m_nInsertSuccess = 0; - size_t m_nInsertFailed = 0; - size_t m_nFindSuccess = 0; - size_t m_nFindFail = 0; - - public: - Inserter( cds_test::thread_pool& pool, Map& map ) - : base_class( pool ) - , m_Map( map ) - { - make_array(); - } - - Inserter( Inserter& src ) - : base_class( src ) - , m_Map( src.m_Map ) - { - make_array(); - } - - virtual thread * clone() - { - return new Inserter( *this ); - } - - virtual void test() - { - Map& rMap = m_Map; - - size_t const nArrSize = m_arrVal.size(); - for ( size_t i = 0; i < nArrSize; ++i ) { - size_t const nItem = m_arrVal[i]; - if ( check_result( rMap.insert( nItem, nItem * 8 ), rMap )) - ++m_nInsertSuccess; - else - ++m_nInsertFailed; - - for ( size_t k = 0; k <= i; ++k ) { - if ( check_result( rMap.contains( m_arrVal[k] ), rMap )) - ++m_nFindSuccess; - else - ++m_nFindFail; - } - } - } - }; - - protected: - - template - void do_test( Map& testMap ) - { - typedef Inserter inserter; - - cds_test::thread_pool& pool = get_pool(); - pool.add( new inserter( pool, testMap ), s_nThreadCount ); - - propout() - << std::make_pair( "thread_count", s_nThreadCount ) - << std::make_pair( "insert_per_thread", s_nMapSize ); - - std::chrono::milliseconds duration = pool.run(); - - propout() << std::make_pair( "duration", duration ); - - size_t nInsertSuccess = 0; - size_t nInsertFailed = 0; - size_t nFindSuccess = 0; - size_t nFindFailed = 0; - for ( size_t i = 0; i < pool.size(); ++i ) { - inserter& thr = static_cast(pool.get( i )); - - EXPECT_EQ( thr.m_nInsertFailed, 0u ) << "thread " << thr.id(); - EXPECT_EQ( thr.m_nFindFail, 0u ) << "thread " << thr.id(); - - nInsertSuccess += thr.m_nInsertSuccess; - nInsertFailed += thr.m_nInsertFailed; - nFindSuccess += thr.m_nFindSuccess; - nFindFailed += thr.m_nFindFail; - } - - propout() - << std::make_pair( "insert_success", nInsertSuccess ) - << std::make_pair( "insert_failed", nInsertFailed ) - << std::make_pair( "find_success", nFindSuccess ) - << std::make_pair( "find_failed", nFindFailed ) - << std::make_pair( "finish_map_size", testMap.size()); - - EXPECT_EQ( nInsertFailed, 0u ); - EXPECT_EQ( nFindFailed, 0u ); - - check_before_cleanup( testMap ); - - testMap.clear(); - additional_check( testMap ); - print_stat( propout(), testMap ); - additional_cleanup( testMap ); - } - - template - void run_test() - { - Map testMap( *this ); - do_test( testMap ); - } - }; - - class Map_InsFind_int_LF: public Map_InsFind_int - , public ::testing::WithParamInterface - { - public: - template - void run_test() - { - s_nLoadFactor = GetParam(); - propout() << std::make_pair( "load_factor", s_nLoadFactor ); - Map_InsFind_int::run_test(); - } - - static std::vector get_load_factors(); - }; - -} // namespace map diff --git a/test/stress/map/insfind_int/map_insfind_michael.cpp b/test/stress/map/insfind_int/map_insfind_michael.cpp deleted file mode 100644 index 00e98d8c..00000000 --- a/test/stress/map/insfind_int/map_insfind_michael.cpp +++ /dev/null @@ -1,39 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_insfind_int.h" -#include "map_type_michael.h" - -namespace map { - - CDSSTRESS_MichaelMap( Map_InsFind_int_LF, run_test, size_t, size_t ) - CDSSTRESS_MichaelMap_nogc( Map_InsFind_int_LF, run_test, size_t, size_t ) - -} // namespace map diff --git a/test/stress/map/insfind_int/map_insfind_skip.cpp b/test/stress/map/insfind_int/map_insfind_skip.cpp deleted file mode 100644 index 78cd387e..00000000 --- a/test/stress/map/insfind_int/map_insfind_skip.cpp +++ /dev/null @@ -1,39 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_insfind_int.h" -#include "map_type_skip_list.h" - -namespace map { - - CDSSTRESS_SkipListMap( Map_InsFind_int, run_test, size_t, size_t ) - CDSSTRESS_SkipListMap_nogc( Map_InsFind_int, run_test, size_t, size_t ) - -} // namespace map diff --git a/test/stress/map/insfind_int/map_insfind_split.cpp b/test/stress/map/insfind_int/map_insfind_split.cpp deleted file mode 100644 index 2ff30247..00000000 --- a/test/stress/map/insfind_int/map_insfind_split.cpp +++ /dev/null @@ -1,40 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_insfind_int.h" -#include "map_type_split_list.h" - -namespace map { - - CDSSTRESS_SplitListMap( Map_InsFind_int_LF, run_test, size_t, size_t ) - CDSSTRESS_SplitListIterableMap( Map_InsFind_int_LF, run_test, size_t, size_t ) - CDSSTRESS_SplitListMap_nogc( Map_InsFind_int_LF, run_test, size_t, size_t ) - -} // namespace map diff --git a/test/stress/map/insfind_int/map_insfind_striped.cpp b/test/stress/map/insfind_int/map_insfind_striped.cpp deleted file mode 100644 index 3dfb8832..00000000 --- a/test/stress/map/insfind_int/map_insfind_striped.cpp +++ /dev/null @@ -1,38 +0,0 @@ -/* - This file is a part of libcds - Concurrent Data Structures library - - (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 - - Source code repo: http://github.com/khizmax/libcds/ - Download: http://sourceforge.net/projects/libcds/files/ - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, this - list of conditions and the following disclaimer. - - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ - -#include "map_insfind_int.h" -#include "map_type_striped.h" - -namespace map { - - CDSSTRESS_StripedMap( Map_InsFind_int_LF, run_test, size_t, size_t ) - -} // namespace map diff --git a/test/stress/set/CMakeLists.txt b/test/stress/set/CMakeLists.txt index f689f08d..3f326fa9 100644 --- a/test/stress/set/CMakeLists.txt +++ b/test/stress/set/CMakeLists.txt @@ -2,6 +2,7 @@ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DCDSUNIT_USE_URCU") add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/delodd) +add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/del3) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdel_find) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdel_func) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/insdel_string) @@ -10,6 +11,7 @@ add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/iteration) add_custom_target( stress-set DEPENDS stress-set-delodd + stress-set-del3 stress-set-insdelfind stress-set-insdel-func stress-set-insdel-string diff --git a/test/stress/set/del3/CMakeLists.txt b/test/stress/set/del3/CMakeLists.txt new file mode 100644 index 00000000..1ebfa49e --- /dev/null +++ b/test/stress/set/del3/CMakeLists.txt @@ -0,0 +1,28 @@ +set(PACKAGE_NAME stress-set-del3) + +set(CDSSTRESS_SET_DEL3_SOURCES + ../../main.cpp + set_del3.cpp + set_del3_cuckoo.cpp + set_del3_ellentree.cpp + set_del3_feldman_hashset.cpp + set_del3_michael.cpp + set_del3_skip.cpp + set_del3_split.cpp +) + +include_directories( + ${CMAKE_CURRENT_SOURCE_DIR} + ${CMAKE_CURRENT_SOURCE_DIR}/.. +) + +add_executable(${PACKAGE_NAME} ${CDSSTRESS_SET_DEL3_SOURCES} $) +target_link_libraries(${PACKAGE_NAME} + ${CDS_SHARED_LIBRARY} + ${GTEST_LIBRARY} + ${Boost_THREAD_LIBRARY} + ${Boost_SYSTEM_LIBRARY} + ${CMAKE_THREAD_LIBS_INIT} +) + +add_test(NAME ${PACKAGE_NAME} COMMAND ${PACKAGE_NAME} WORKING_DIRECTORY ${EXECUTABLE_OUTPUT_PATH}) \ No newline at end of file diff --git a/test/stress/map/insfind_int/map_insfind.cpp b/test/stress/set/del3/set_del3.cpp similarity index 51% rename from test/stress/map/insfind_int/map_insfind.cpp rename to test/stress/set/del3/set_del3.cpp index 7e7d62c9..e365cd0c 100644 --- a/test/stress/map/insfind_int/map_insfind.cpp +++ b/test/stress/set/del3/set_del3.cpp @@ -28,39 +28,53 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_insfind_int.h" +#include "set_del3.h" -namespace map { +namespace set { - size_t Map_InsFind_int::s_nMapSize = 500000; - size_t Map_InsFind_int::s_nThreadCount = 8; - size_t Map_InsFind_int::s_nMaxLoadFactor = 8; + size_t Set_Del3::s_nSetSize = 1000000; + size_t Set_Del3::s_nInsThreadCount = 4; + size_t Set_Del3::s_nDelThreadCount = 4; + size_t Set_Del3::s_nExtractThreadCount = 4; + size_t Set_Del3::s_nFindThreadCount = 2; + size_t Set_Del3::s_nMaxLoadFactor = 8; + size_t Set_Del3::s_nInsertPassCount = 100; - size_t Map_InsFind_int::s_nCuckooInitialSize = 1024; // initial size for CuckooSet - size_t Map_InsFind_int::s_nCuckooProbesetSize = 16; // CuckooSet probeset size (only for list-based probeset) - size_t Map_InsFind_int::s_nCuckooProbesetThreshold = 0; // CuckooSet probeset threshold (0 - use default) + size_t Set_Del3::s_nCuckooInitialSize = 1024; + size_t Set_Del3::s_nCuckooProbesetSize = 16; + size_t Set_Del3::s_nCuckooProbesetThreshold = 0; - size_t Map_InsFind_int::s_nFeldmanMap_HeadBits = 10; - size_t Map_InsFind_int::s_nFeldmanMap_ArrayBits = 4; + size_t Set_Del3::s_nFeldmanSet_HeadBits = 10; + size_t Set_Del3::s_nFeldmanSet_ArrayBits = 4; - size_t Map_InsFind_int::s_nLoadFactor = 1; - void Map_InsFind_int::SetUpTestCase() + size_t Set_Del3::s_nLoadFactor = 1; + std::vector Set_Del3::m_arrData; + + void Set_Del3::SetUpTestCase() { - cds_test::config const& cfg = get_config( "map_insfind_int" ); + cds_test::config const& cfg = get_config( "map_delodd" ); + + s_nSetSize = cfg.get_size_t( "MapSize", s_nSetSize ); + if ( s_nSetSize < 1000 ) + s_nSetSize = 1000; - s_nMapSize = cfg.get_size_t( "MapSize", s_nMapSize ); - if ( s_nMapSize < 100 ) - s_nMapSize = 100; + s_nInsThreadCount = cfg.get_size_t( "InsThreadCount", s_nInsThreadCount ); + if ( s_nInsThreadCount == 0 ) + s_nInsThreadCount = 1; - s_nThreadCount = cfg.get_size_t( "ThreadCount", s_nThreadCount ); - if ( s_nThreadCount == 0 ) - s_nThreadCount = std::thread::hardware_concurrency() * 2; + s_nDelThreadCount = cfg.get_size_t( "DelThreadCount", s_nDelThreadCount ); + s_nExtractThreadCount = cfg.get_size_t( "ExtractThreadCount", s_nExtractThreadCount ); + s_nFindThreadCount = cfg.get_size_t( "FindThreadCount", s_nFindThreadCount ); s_nMaxLoadFactor = cfg.get_size_t( "MaxLoadFactor", s_nMaxLoadFactor ); if ( s_nMaxLoadFactor == 0 ) s_nMaxLoadFactor = 1; + s_nInsertPassCount = cfg.get_size_t( "PassCount", s_nInsertPassCount ); + if ( s_nInsertPassCount == 0 ) + s_nInsertPassCount = 100; + s_nCuckooInitialSize = cfg.get_size_t( "CuckooInitialSize", s_nCuckooInitialSize ); if ( s_nCuckooInitialSize < 256 ) s_nCuckooInitialSize = 256; @@ -71,18 +85,28 @@ namespace map { s_nCuckooProbesetThreshold = cfg.get_size_t( "CuckooProbesetThreshold", s_nCuckooProbesetThreshold ); - s_nFeldmanMap_HeadBits = cfg.get_size_t( "FeldmanMapHeadBits", s_nFeldmanMap_HeadBits ); - if ( s_nFeldmanMap_HeadBits == 0 ) - s_nFeldmanMap_HeadBits = 2; + s_nFeldmanSet_HeadBits = cfg.get_size_t( "FeldmanMapHeadBits", s_nFeldmanSet_HeadBits ); + if ( s_nFeldmanSet_HeadBits == 0 ) + s_nFeldmanSet_HeadBits = 2; + + s_nFeldmanSet_ArrayBits = cfg.get_size_t( "FeldmanMapArrayBits", s_nFeldmanSet_ArrayBits ); + if ( s_nFeldmanSet_ArrayBits == 0 ) + s_nFeldmanSet_ArrayBits = 2; - s_nFeldmanMap_ArrayBits = cfg.get_size_t( "FeldmanMapArrayBits", s_nFeldmanMap_ArrayBits ); - if ( s_nFeldmanMap_ArrayBits == 0 ) - s_nFeldmanMap_ArrayBits = 2; + m_arrData.resize( s_nSetSize ); + for ( size_t i = 0; i < s_nSetSize; ++i ) + m_arrData[i] = i; + shuffle( m_arrData.begin(), m_arrData.end()); + } + + void Set_Del3::TearDownTestCase() + { + m_arrData.clear(); } - std::vector Map_InsFind_int_LF::get_load_factors() + std::vector Set_Del3_LF::get_load_factors() { - cds_test::config const& cfg = get_config( "map_insfind_int" ); + cds_test::config const& cfg = get_config( "map_delodd" ); s_nMaxLoadFactor = cfg.get_size_t( "MaxLoadFactor", s_nMaxLoadFactor ); if ( s_nMaxLoadFactor == 0 ) @@ -95,5 +119,5 @@ namespace map { return lf; } - INSTANTIATE_TEST_CASE_P( a, Map_InsFind_int_LF, ::testing::ValuesIn( Map_InsFind_int_LF::get_load_factors())); -} // namespace map + INSTANTIATE_TEST_CASE_P( a, Set_Del3_LF, ::testing::ValuesIn( Set_Del3_LF::get_load_factors())); +} // namespace set diff --git a/test/stress/set/del3/set_del3.h b/test/stress/set/del3/set_del3.h new file mode 100644 index 00000000..012cb9d3 --- /dev/null +++ b/test/stress/set/del3/set_del3.h @@ -0,0 +1,921 @@ +/* + This file is a part of libcds - Concurrent Data Structures library + + (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 + + Source code repo: http://github.com/khizmax/libcds/ + Download: http://sourceforge.net/projects/libcds/files/ + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE + FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER + CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, + OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +*/ + +#include "set_type.h" +#include + +namespace set { + + struct key_thread + { + uint32_t nKey; + uint16_t nThread; + + key_thread( size_t key, size_t threadNo ) + : nKey( static_cast(key)) + , nThread( static_cast(threadNo)) + {} + + key_thread() + : nKey() + , nThread() + {} + }; + + static_assert(sizeof( key_thread ) % 8 == 0, "Key type size mismatch"); + + typedef set_type_base::key_val key_value_pair; + + template <> + struct cmp { + int operator ()(key_thread const& k1, key_thread const& k2) const + { + if ( k1.nKey < k2.nKey ) + return -1; + if ( k1.nKey > k2.nKey ) + return 1; + if ( k1.nThread < k2.nThread ) + return -1; + if ( k1.nThread > k2.nThread ) + return 1; + return 0; + } + int operator ()(key_thread const& k1, size_t k2) const + { + if ( k1.nKey < k2 ) + return -1; + if ( k1.nKey > k2 ) + return 1; + return 0; + } + int operator ()(size_t k1, key_thread const& k2) const + { + if ( k1 < k2.nKey ) + return -1; + if ( k1 > k2.nKey ) + return 1; + return 0; + } + }; + + template <> + struct less + { + bool operator()( set::key_thread const& k1, set::key_thread const& k2 ) const + { + if ( k1.nKey <= k2.nKey ) + return k1.nKey < k2.nKey || k1.nThread < k2.nThread; + return false; + } + }; + + template <> + struct hash + { + typedef size_t result_type; + typedef set::key_thread argument_type; + + size_t operator()( set::key_thread const& k ) const + { + return std::hash()(k.nKey); + } + + size_t operator()( size_t k ) const + { + return std::hash()(k); + } + }; + + + class Set_Del3: public cds_test::stress_fixture + { + public: + static size_t s_nSetSize; // max set size + static size_t s_nInsThreadCount; // insert thread count + static size_t s_nDelThreadCount; // delete thread count + static size_t s_nExtractThreadCount; // extract thread count + static size_t s_nMaxLoadFactor; // maximum load factor + static size_t s_nInsertPassCount; + static size_t s_nFindThreadCount; // find thread count + + static size_t s_nCuckooInitialSize; // initial size for CuckooSet + static size_t s_nCuckooProbesetSize; // CuckooSet probeset size (only for list-based probeset) + static size_t s_nCuckooProbesetThreshold; // CUckooSet probeset threshold (0 - use default) + + static size_t s_nFeldmanSet_HeadBits; + static size_t s_nFeldmanSet_ArrayBits; + + static size_t s_nLoadFactor; + + static std::vector m_arrData; + + static void SetUpTestCase(); + static void TearDownTestCase(); + + template + static void prepare_array( std::vector& arr, Pred pred ) + { + arr.reserve( m_arrData.size()); + for ( auto el : m_arrData ) { + if ( pred( el )) + arr.push_back( el ); + } + arr.resize( arr.size()); + shuffle( arr.begin(), arr.end()); + } + + protected: + typedef key_thread key_type; + typedef size_t value_type; + + atomics::atomic m_nInsThreadCount; + + enum { + inserter_thread, + deleter_thread, + extractor_thread, + find_thread + }; + + + // Inserts keys from [0..N) + template + class Inserter: public cds_test::thread + { + typedef cds_test::thread base_class; + Set& m_Set; + + struct update_functor + { + template + void operator()( bool /*bNew*/, key_value_pair const&, Q const& ) const + {} + + void operator()(key_value_pair& /*cur*/, key_value_pair * /*prev*/) const + {} + }; + + void init_data() + { + prepare_array( m_arr, []( size_t ) -> bool { return true; } ); + for ( size_t i = 0; i < m_arr.size(); ++i ) { + if ( m_Set.insert( key_type( m_arr[i], id()))) + ++m_nInsertInitSuccess; + else + ++m_nInsertInitFailed; + } + } + + public: + size_t m_nInsertSuccess = 0; + size_t m_nInsertFailed = 0; + size_t m_nInsertInitSuccess = 0; + size_t m_nInsertInitFailed = 0; + + std::vector m_arr; + + public: + Inserter( cds_test::thread_pool& pool, Set& set ) + : base_class( pool, inserter_thread ) + , m_Set( set ) + { + init_data(); + } + + Inserter( Inserter& src ) + : base_class( src ) + , m_Set( src.m_Set ) + { + init_data(); + } + + virtual thread * clone() + { + return new Inserter( *this ); + } + + virtual void test() + { + Set& rSet = m_Set; + Set_Del3& fixture = pool().template fixture(); + + for ( size_t nPass = 0; nPass < s_nInsertPassCount; ++nPass ) { + if ( nPass & 1 ) { + // insert pass + for ( auto el : m_arr ) { + if ( el & 3 ) { + if ( rSet.insert( key_type( el, id()))) + ++m_nInsertSuccess; + else + ++m_nInsertFailed; + } + } + } + else { + // update pass + for ( auto el : m_arr ) { + if ( el & 3 ) { + bool success; + bool inserted; + std::tie( success, inserted ) = rSet.update( key_type( el, id()), update_functor()); + if ( success && inserted ) + ++m_nInsertSuccess; + else + ++m_nInsertFailed; + } + } + } + } + + fixture.m_nInsThreadCount.fetch_sub( 1, atomics::memory_order_release ); + m_arr.resize( 0 ); + } + }; + + struct key_equal { + bool operator()( key_type const& k1, key_type const& k2 ) const + { + return k1.nKey == k2.nKey; + } + bool operator()( size_t k1, key_type const& k2 ) const + { + return k1 == k2.nKey; + } + bool operator()( key_type const& k1, size_t k2 ) const + { + return k1.nKey == k2; + } + bool operator ()( key_value_pair const& k1, key_value_pair const& k2 ) const + { + return operator()( k1.key, k2.key ); + } + bool operator ()( key_value_pair const& k1, key_type const& k2 ) const + { + return operator()( k1.key, k2 ); + } + bool operator ()( key_type const& k1, key_value_pair const& k2 ) const + { + return operator()( k1, k2.key ); + } + bool operator ()( key_value_pair const& k1, size_t k2 ) const + { + return operator()( k1.key, k2 ); + } + bool operator ()( size_t k1, key_value_pair const& k2 ) const + { + return operator()( k1, k2.key ); + } + }; + + struct key_less { + bool operator()( key_type const& k1, key_type const& k2 ) const + { + return k1.nKey < k2.nKey; + } + bool operator()( size_t k1, key_type const& k2 ) const + { + return k1 < k2.nKey; + } + bool operator()( key_type const& k1, size_t k2 ) const + { + return k1.nKey < k2; + } + bool operator ()( key_value_pair const& k1, key_value_pair const& k2 ) const + { + return operator()( k1.key, k2.key ); + } + bool operator ()( key_value_pair const& k1, key_type const& k2 ) const + { + return operator()( k1.key, k2 ); + } + bool operator ()( key_type const& k1, key_value_pair const& k2 ) const + { + return operator()( k1, k2.key ); + } + bool operator ()( key_value_pair const& k1, size_t k2 ) const + { + return operator()( k1.key, k2 ); + } + bool operator ()( size_t k1, key_value_pair const& k2 ) const + { + return operator()( k1, k2.key ); + } + + typedef key_equal equal_to; + }; + + // Deletes odd keys from [0..N) + template + class Deleter: public cds_test::thread + { + typedef cds_test::thread base_class; + Set& m_Set; + + void init_data() + { + prepare_array( m_arr, []( size_t el ) ->bool { return ( el & 3 ) != 0; } ); + } + + public: + size_t m_nDeleteSuccess = 0; + size_t m_nDeleteFailed = 0; + + std::vector m_arr; + + public: + Deleter( cds_test::thread_pool& pool, Set& set ) + : base_class( pool, deleter_thread ) + , m_Set( set ) + { + init_data(); + } + Deleter( Deleter& src ) + : base_class( src ) + , m_Set( src.m_Set ) + { + init_data(); + } + + virtual thread * clone() + { + return new Deleter( *this ); + } + + template + struct eraser { + static bool erase( SetType& s, size_t key, size_t /*thread*/) + { + return s.erase_with( key, key_less()); + } + }; + + template + struct eraser { + static bool erase(SetType& s, size_t key, size_t thread) + { + return s.erase( key_type(key, thread)); + } + }; + + virtual void test() + { + Set& rSet = m_Set; + + size_t const nInsThreadCount = s_nInsThreadCount; + Set_Del3& fixture = pool().template fixture(); + + do { + if ( id() & 1 ) { + for ( auto el : m_arr ) { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + if ( rSet.erase( key_type( el, k ))) + ++m_nDeleteSuccess; + else + ++m_nDeleteFailed; + } + } + } + else { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + for ( auto el : m_arr ) { + if ( rSet.erase( key_type( el, k ))) + ++m_nDeleteSuccess; + else + ++m_nDeleteFailed; + } + } + } + } while ( fixture.m_nInsThreadCount.load( atomics::memory_order_acquire ) != 0 ); + + m_arr.resize( 0 ); + } + }; + + // Extracts odd keys from [0..N) + template + class Extractor: public cds_test::thread + { + typedef cds_test::thread base_class; + Set& m_Set; + + std::vector m_arr; + + void init_data() + { + prepare_array( m_arr, []( size_t el ) ->bool { return ( el & 3 ) != 0; } ); + } + + public: + size_t m_nExtractSuccess = 0; + size_t m_nExtractFailed = 0; + + public: + Extractor( cds_test::thread_pool& pool, Set& set ) + : base_class( pool, extractor_thread ) + , m_Set( set ) + { + init_data(); + } + + Extractor( Extractor& src ) + : base_class( src ) + , m_Set( src.m_Set ) + { + init_data(); + } + + virtual thread * clone() + { + return new Extractor( *this ); + } + + virtual void test() + { + Set& rSet = m_Set; + typename Set::guarded_ptr gp; + + Set_Del3& fixture = pool().template fixture(); + size_t const nInsThreadCount = s_nInsThreadCount; + + do { + if ( id() & 1 ) { + for ( auto el : m_arr ) { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + gp = rSet.extract( key_type( el, k )); + if ( gp ) + ++m_nExtractSuccess; + else + ++m_nExtractFailed; + gp.release(); + } + } + } + else { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + for ( auto el : m_arr ) { + gp = rSet.extract( key_type( el, k )); + if ( gp ) + ++m_nExtractSuccess; + else + ++m_nExtractFailed; + gp.release(); + } + } + } + } while ( fixture.m_nInsThreadCount.load( atomics::memory_order_acquire ) != 0 ); + + m_arr.resize( 0 ); + } + }; + + template + class Extractor< cds::urcu::gc, Set >: public cds_test::thread + { + typedef cds_test::thread base_class; + Set& m_Set; + std::vector m_arr; + + void init_data() + { + prepare_array( m_arr, []( size_t el ) -> bool { return ( el & 3 ) != 0; } ); + } + + public: + size_t m_nExtractSuccess = 0; + size_t m_nExtractFailed = 0; + + public: + Extractor( cds_test::thread_pool& pool, Set& set ) + : base_class( pool, extractor_thread ) + , m_Set( set ) + { + init_data(); + } + + Extractor( Extractor& src ) + : base_class( src ) + , m_Set( src.m_Set ) + { + init_data(); + } + + virtual thread * clone() + { + return new Extractor( *this ); + } + + virtual void test() + { + Set& rSet = m_Set; + typename Set::exempt_ptr xp; + + Set_Del3& fixture = pool().template fixture(); + size_t const nInsThreadCount = fixture.s_nInsThreadCount; + + do { + if ( id() & 1 ) { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + for ( auto el : m_arr ) { + if ( Set::c_bExtractLockExternal ) { + typename Set::rcu_lock l; + xp = rSet.extract( key_type( el, k )); + if ( xp ) + ++m_nExtractSuccess; + else + ++m_nExtractFailed; + } + else { + xp = rSet.extract( key_type( el, k )); + if ( xp ) + ++m_nExtractSuccess; + else + ++m_nExtractFailed; + } + xp.release(); + } + } + } + else { + for ( auto el : m_arr ) { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + if ( Set::c_bExtractLockExternal ) { + typename Set::rcu_lock l; + xp = rSet.extract( key_type( el, k )); + if ( xp ) + ++m_nExtractSuccess; + else + ++m_nExtractFailed; + } + else { + xp = rSet.extract( key_type( el, k )); + if ( xp ) + ++m_nExtractSuccess; + else + ++m_nExtractFailed; + } + xp.release(); + } + } + } + } while ( fixture.m_nInsThreadCount.load( atomics::memory_order_acquire ) != 0 ); + + m_arr.resize( 0 ); + } + }; + + // Finds keys + template + class Observer: public cds_test::thread + { + typedef cds_test::thread base_class; + Set& m_Set; + + public: + size_t m_nFindEvenSuccess = 0; + size_t m_nFindEvenFailed = 0; + size_t m_nFindOddSuccess = 0; + size_t m_nFindOddFailed = 0; + + public: + Observer( cds_test::thread_pool& pool, Set& set ) + : base_class( pool, find_thread ) + , m_Set( set ) + {} + + Observer( Observer& src ) + : base_class( src ) + , m_Set( src.m_Set ) + {} + + virtual thread * clone() + { + return new Observer( *this ); + } + + virtual void test() + { + Set& set = m_Set; + Set_Del3& fixture = pool().template fixture(); + std::vector const& arr = m_arrData; + size_t const nInsThreadCount = s_nInsThreadCount; + + do { + for ( size_t key : arr ) { + if ( key & 3 ) { + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + if ( set.contains( key_thread( key, k ))) + ++m_nFindOddSuccess; + else + ++m_nFindOddFailed; + } + } + else { + // even keys MUST be in the map + for ( size_t k = 0; k < nInsThreadCount; ++k ) { + if ( set.contains( key_thread( key, k ))) + ++m_nFindEvenSuccess; + else + ++m_nFindEvenFailed; + } + } + } + } while ( fixture.m_nInsThreadCount.load( atomics::memory_order_acquire ) != 0 ); + } + }; + + protected: + template + void do_test_with( Set& testSet ) + { + typedef Inserter insert_thread; + typedef Deleter delete_thread; + typedef Observer observer_thread; + + m_nInsThreadCount.store( s_nInsThreadCount, atomics::memory_order_release ); + + cds_test::thread_pool& pool = get_pool(); + pool.add( new insert_thread( pool, testSet ), s_nInsThreadCount ); + pool.add( new delete_thread( pool, testSet ), s_nDelThreadCount ? s_nDelThreadCount : cds::OS::topology::processor_count()); + if ( s_nFindThreadCount ) + pool.add( new observer_thread( pool, testSet ), s_nFindThreadCount ); + + propout() << std::make_pair( "insert_thread_count", s_nInsThreadCount ) + << std::make_pair( "delete_thread_count", s_nDelThreadCount ) + << std::make_pair( "find_thread_count", s_nFindThreadCount ) + << std::make_pair( "set_size", s_nSetSize ) + << std::make_pair( "pass_count", s_nInsertPassCount ); + + std::chrono::milliseconds duration = pool.run(); + + propout() << std::make_pair( "duration", duration ); + + size_t nInsertInitFailed = 0; + size_t nInsertInitSuccess = 0; + size_t nInsertSuccess = 0; + size_t nInsertFailed = 0; + size_t nDeleteSuccess = 0; + size_t nDeleteFailed = 0; + + size_t nFindEvenSuccess = 0; + size_t nFindEvenFailed = 0; + size_t nFindOddSuccess = 0; + size_t nFindOddFailed = 0; + + for ( size_t i = 0; i < pool.size(); ++i ) { + cds_test::thread& thr = pool.get( i ); + switch ( thr.type()) { + case inserter_thread: + { + insert_thread& inserter = static_cast(thr); + nInsertSuccess += inserter.m_nInsertSuccess; + nInsertFailed += inserter.m_nInsertFailed; + nInsertInitSuccess += inserter.m_nInsertInitSuccess; + nInsertInitFailed += inserter.m_nInsertInitFailed; + } + break; + case deleter_thread: + { + delete_thread& deleter = static_cast(thr); + nDeleteSuccess += deleter.m_nDeleteSuccess; + nDeleteFailed += deleter.m_nDeleteFailed; + } + break; + case find_thread: + { + observer_thread& observer = static_cast( thr ); + nFindEvenSuccess = observer.m_nFindEvenSuccess; + nFindEvenFailed = observer.m_nFindEvenFailed; + nFindOddSuccess = observer.m_nFindOddSuccess; + nFindOddFailed = observer.m_nFindOddFailed; + } + break; + default: + assert( false ); + } + } + + size_t const nInitialOddKeys = ( s_nSetSize * s_nInsThreadCount ) * 3 / 4; + + EXPECT_EQ( nInsertInitFailed, 0u ); + EXPECT_EQ( nInsertInitSuccess, s_nSetSize * s_nInsThreadCount ); + EXPECT_EQ( nFindEvenFailed, 0u ); + EXPECT_GE( nInsertSuccess + nInitialOddKeys, nDeleteSuccess ); + EXPECT_LE( nInsertSuccess, nDeleteSuccess ); + + propout() + << std::make_pair( "insert_init_success", nInsertInitSuccess ) + << std::make_pair( "insert_init_failed", nInsertInitFailed ) + << std::make_pair( "insert_success", nInsertSuccess ) + << std::make_pair( "insert_failed", nInsertFailed ) + << std::make_pair( "delete_success", nDeleteSuccess ) + << std::make_pair( "delete_failed", nDeleteFailed ) + << std::make_pair( "find_even_success", nFindEvenSuccess ) + << std::make_pair( "find_even_failed", nFindEvenFailed ) + << std::make_pair( "find_odd_success", nFindOddSuccess ) + << std::make_pair( "find_odd_failed", nFindOddFailed ); + } + + template + void do_test_extract_with( Set& testSet ) + { + typedef Inserter insert_thread; + typedef Deleter delete_thread; + typedef Extractor< typename Set::gc, Set > extract_thread; + typedef Observer observer_thread; + + m_nInsThreadCount.store( s_nInsThreadCount, atomics::memory_order_release ); + + cds_test::thread_pool& pool = get_pool(); + pool.add( new insert_thread( pool, testSet ), s_nInsThreadCount ); + if ( s_nDelThreadCount ) + pool.add( new delete_thread( pool, testSet ), s_nDelThreadCount ); + if ( s_nExtractThreadCount ) + pool.add( new extract_thread( pool, testSet ), s_nExtractThreadCount ); + if ( s_nFindThreadCount ) + pool.add( new observer_thread( pool, testSet ), s_nFindThreadCount ); + + propout() << std::make_pair( "insert_thread_count", s_nInsThreadCount ) + << std::make_pair( "delete_thread_count", s_nDelThreadCount ) + << std::make_pair( "extract_thread_count", s_nExtractThreadCount ) + << std::make_pair( "find_thread_count", s_nFindThreadCount ) + << std::make_pair( "set_size", s_nSetSize ) + << std::make_pair( "pass_count", s_nInsertPassCount ); + + std::chrono::milliseconds duration = pool.run(); + + propout() << std::make_pair( "duration", duration ); + + size_t nInsertInitFailed = 0; + size_t nInsertInitSuccess = 0; + size_t nInsertSuccess = 0; + size_t nInsertFailed = 0; + size_t nDeleteSuccess = 0; + size_t nDeleteFailed = 0; + size_t nExtractSuccess = 0; + size_t nExtractFailed = 0; + + size_t nFindEvenSuccess = 0; + size_t nFindEvenFailed = 0; + size_t nFindOddSuccess = 0; + size_t nFindOddFailed = 0; + + for ( size_t i = 0; i < pool.size(); ++i ) { + cds_test::thread& thr = pool.get( i ); + switch ( thr.type()) { + case inserter_thread: + { + insert_thread& inserter = static_cast( thr ); + nInsertSuccess += inserter.m_nInsertSuccess; + nInsertFailed += inserter.m_nInsertFailed; + nInsertInitSuccess += inserter.m_nInsertInitSuccess; + nInsertInitFailed += inserter.m_nInsertInitFailed; + } + break; + case deleter_thread: + { + delete_thread& deleter = static_cast(thr); + nDeleteSuccess += deleter.m_nDeleteSuccess; + nDeleteFailed += deleter.m_nDeleteFailed; + } + break; + case extractor_thread: + { + extract_thread& extractor = static_cast(thr); + nExtractSuccess += extractor.m_nExtractSuccess; + nExtractFailed += extractor.m_nExtractFailed; + } + break; + case find_thread: + { + observer_thread& observer = static_cast( thr ); + nFindEvenSuccess = observer.m_nFindEvenSuccess; + nFindEvenFailed = observer.m_nFindEvenFailed; + nFindOddSuccess = observer.m_nFindOddSuccess; + nFindOddFailed = observer.m_nFindOddFailed; + } + break; + default: + assert( false ); + } + } + + size_t const nInitialOddKeys = ( s_nSetSize * s_nInsThreadCount ) * 3 / 4; + + EXPECT_EQ( nInsertInitFailed, 0u ); + EXPECT_EQ( nInsertInitSuccess, s_nSetSize * s_nInsThreadCount ); + EXPECT_EQ( nFindEvenFailed, 0u ); + EXPECT_GE( nInsertSuccess + nInitialOddKeys, nDeleteSuccess + nExtractSuccess ); + EXPECT_LE( nInsertSuccess, nDeleteSuccess + nExtractSuccess ); + + propout() + << std::make_pair( "insert_init_success", nInsertInitSuccess ) + << std::make_pair( "insert_init_failed", nInsertInitFailed ) + << std::make_pair( "insert_success", nInsertSuccess ) + << std::make_pair( "insert_failed", nInsertFailed ) + << std::make_pair( "delete_success", nDeleteSuccess ) + << std::make_pair( "delete_failed", nDeleteFailed ) + << std::make_pair( "extract_success", nExtractSuccess ) + << std::make_pair( "extract_failed", nExtractFailed ) + << std::make_pair( "find_even_success", nFindEvenSuccess ) + << std::make_pair( "find_even_failed", nFindEvenFailed ) + << std::make_pair( "find_odd_success", nFindOddSuccess ) + << std::make_pair( "find_odd_failed", nFindOddFailed ); + } + + template + void analyze( Set& testSet ) + { + // All even keys must be in the set + { + for ( size_t n = 0; n < s_nSetSize; n +=4 ) { + for ( size_t i = 0; i < s_nInsThreadCount; ++i ) { + EXPECT_TRUE( testSet.contains( key_type( n, i ))) << "key=" << n << "/" << i; + } + } + } + + check_before_clear( testSet ); + + testSet.clear(); + EXPECT_TRUE( testSet.empty()) << "set.size=" << testSet.size(); + + additional_check( testSet ); + print_stat( propout(), testSet ); + additional_cleanup( testSet ); + } + + template + void run_test() + { + static_assert( !Set::c_bExtractSupported, "Set class must not support extract() method" ); + + Set testSet( *this ); + do_test_with( testSet ); + analyze( testSet ); + } + + template + void run_test_extract() + { + static_assert( Set::c_bExtractSupported, "Set class must support extract() method" ); + + Set testSet( *this ); + do_test_extract_with( testSet ); + analyze( testSet ); + } + + template + void run_feldman(); + }; + + class Set_Del3_LF: public Set_Del3 + , public ::testing::WithParamInterface + { + public: + template + void run_test() + { + s_nLoadFactor = GetParam(); + propout() << std::make_pair( "load_factor", s_nLoadFactor ); + Set_Del3::run_test(); + } + + template + void run_test_extract() + { + s_nLoadFactor = GetParam(); + propout() << std::make_pair( "load_factor", s_nLoadFactor ); + Set_Del3::run_test_extract(); + } + + static std::vector get_load_factors(); + }; + +} // namespace set diff --git a/test/stress/map/insfind_int/map_insfind_std.cpp b/test/stress/set/del3/set_del3_cuckoo.cpp similarity index 91% rename from test/stress/map/insfind_int/map_insfind_std.cpp rename to test/stress/set/del3/set_del3_cuckoo.cpp index 6bed8ca0..a11510b5 100644 --- a/test/stress/map/insfind_int/map_insfind_std.cpp +++ b/test/stress/set/del3/set_del3_cuckoo.cpp @@ -28,11 +28,11 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_insfind_int.h" -#include "map_type_std.h" +#include "set_del3.h" +#include "set_type_cuckoo.h" -namespace map { +namespace set { - CDSSTRESS_StdMap( Map_InsFind_int, run_test, size_t, size_t ) + CDSSTRESS_CuckooSet( Set_Del3, run_test, key_thread, size_t ) -} // namespace map +} // namespace set diff --git a/test/stress/set/del3/set_del3_ellentree.cpp b/test/stress/set/del3/set_del3_ellentree.cpp new file mode 100644 index 00000000..53e4f66d --- /dev/null +++ b/test/stress/set/del3/set_del3_ellentree.cpp @@ -0,0 +1,38 @@ +/* + This file is a part of libcds - Concurrent Data Structures library + + (C) Copyright Maxim Khizhinsky (libcds.dev@gmail.com) 2006-2017 + + Source code repo: http://github.com/khizmax/libcds/ + Download: http://sourceforge.net/projects/libcds/files/ + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE + FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER + CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, + OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +*/ + +#include "set_del3.h" +#include "set_type_ellen_bintree.h" + +namespace set { + + CDSSTRESS_EllenBinTreeSet( Set_Del3, run_test_extract, key_thread, size_t ) + +} // namespace set diff --git a/test/stress/map/find_int/map_find_int_ellentree.cpp b/test/stress/set/del3/set_del3_feldman_hashset.cpp similarity index 74% rename from test/stress/map/find_int/map_find_int_ellentree.cpp rename to test/stress/set/del3/set_del3_feldman_hashset.cpp index 319965bd..e6828d91 100644 --- a/test/stress/map/find_int/map_find_int_ellentree.cpp +++ b/test/stress/set/del3/set_del3_feldman_hashset.cpp @@ -28,11 +28,23 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_find_int.h" -#include "map_type_ellen_bintree.h" +#include "set_del3.h" +#include "set_type_feldman_hashset.h" -namespace map { +namespace set { - CDSSTRESS_EllenBinTreeMap( Map_find_int, run_test, size_t, Map_find_int::value_type ) + template + void Set_Del3::run_feldman() + { + typedef typename Set::traits original_traits; + struct traits: public original_traits { + enum { hash_size = sizeof( uint32_t ) + sizeof( uint16_t ) }; + }; + typedef typename Set::template rebind_traits< traits >::result set_type; -} // namespace map + run_test_extract(); + } + + CDSSTRESS_FeldmanHashSet_fixed( Set_Del3, run_feldman, key_thread, size_t ) + +} // namespace set diff --git a/test/stress/map/find_int/map_find_int_bronsonavltree.cpp b/test/stress/set/del3/set_del3_michael.cpp similarity index 86% rename from test/stress/map/find_int/map_find_int_bronsonavltree.cpp rename to test/stress/set/del3/set_del3_michael.cpp index 58d80206..d7e64a02 100644 --- a/test/stress/map/find_int/map_find_int_bronsonavltree.cpp +++ b/test/stress/set/del3/set_del3_michael.cpp @@ -28,11 +28,12 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_find_int.h" -#include "map_type_bronson_avltree.h" +#include "set_del3.h" +#include "set_type_michael.h" -namespace map { +namespace set { - CDSSTRESS_BronsonAVLTreeMap( Map_find_int, run_test, size_t, Map_find_int::value_type ) + CDSSTRESS_MichaelSet( Set_Del3_LF, run_test_extract, key_thread, size_t ) + CDSSTRESS_MichaelIterableSet( Set_Del3_LF, run_test_extract, key_thread, size_t ) -} // namespace map +} // namespace set diff --git a/test/stress/map/insdel_int/map_insdel_int_std.cpp b/test/stress/set/del3/set_del3_skip.cpp similarity index 90% rename from test/stress/map/insdel_int/map_insdel_int_std.cpp rename to test/stress/set/del3/set_del3_skip.cpp index 2a925b4f..9767eebc 100644 --- a/test/stress/map/insdel_int/map_insdel_int_std.cpp +++ b/test/stress/set/del3/set_del3_skip.cpp @@ -28,11 +28,11 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_insdel_int.h" -#include "map_type_std.h" +#include "set_del3.h" +#include "set_type_skip_list.h" -namespace map { +namespace set { - CDSSTRESS_StdMap( Map_InsDel_int, run_test, size_t, size_t ) + CDSSTRESS_SkipListSet( Set_Del3, run_test_extract, key_thread, size_t ) -} // namespace map +} // namespace set diff --git a/test/stress/map/find_int/map_find_int_cuckoo.cpp b/test/stress/set/del3/set_del3_split.cpp similarity index 85% rename from test/stress/map/find_int/map_find_int_cuckoo.cpp rename to test/stress/set/del3/set_del3_split.cpp index 446afab2..73e68330 100644 --- a/test/stress/map/find_int/map_find_int_cuckoo.cpp +++ b/test/stress/set/del3/set_del3_split.cpp @@ -28,11 +28,13 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "map_find_int.h" -#include "map_type_cuckoo.h" +#include "set_del3.h" +#include "set_type_split_list.h" -namespace map { +namespace set { - CDSSTRESS_CuckooMap( Map_find_int, run_test, size_t, Map_find_int::value_type ) + CDSSTRESS_SplitListSet( Set_Del3_LF, run_test_extract, key_thread, size_t ) + CDSSTRESS_SplitListIterableSet( Set_Del3_LF, run_test_extract, key_thread, size_t ) -} // namespace map + +} // namespace set -- 2.34.1