In $:\Dev\msvc\src\qa\VC\Libs\libcxx\upstream\test\std\containers\map_allocator_requirement_test_templates.h and $\test\std\containers\set_allocator_requirement_test_templates.h, libcxx tests are asserting that the container's insert operation passes an incorrect type down to allocator::construct. Specifically, given something like:
{ CHECKPOINT("Testing C::insert(value_type&)"); Container c; ValueTp v(42, 1); cc->expect<const ValueTp&>(); // <-- !!!!! assert(c.insert(v).second); assert(!cc->unchecked()); { DisableAllocationGuard g; ValueTp v2(42, 1); assert(c.insert(v2).second == false); } }
This call to ::insert ends up calling the insert(P&&), not insert(const value_type&), because P is deduced to value_type&, meaning the insert(P&&) overload is an exact match, while insert(const value_type&) requires adding const. See http://eel.is/c++draft/associative#map.modifiers
When the insert(P&&) is called, it delegates to emplace, which only gets Cpp17EmplaceConstructible from the supplied parameters, not Cpp17EmplaceConstructible from add_const_t of the parameters. Thus, libcxx's test is asserting a condition the standard explicitly does not allow at this time. (Though it may be reasonable to fix the standard to make what libcxx is doing okay....)
Unfortunately with the tests fixed to assert the correct allocator::construct call, libc++ will fail these tests. I'm looking for guidance on how libc++ maintainers would like to handle this.
I really think the current behavior libc++ has here is correct.