--- title: Comma quibbling id: 596e414344c3b2872167f0fe challengeType: 5 videoUrl: '' localeTitle: 'Vírgula, quibbling' --- ## Description

Comma quibbling é uma tarefa originalmente definida por Eric Lippert em seu blog .

Tarefa:

Escreva uma função para gerar uma saída de string que é a concatenação de palavras de entrada de uma lista / sequência onde:

Uma entrada sem palavras produz a sequência de saída de apenas os dois caracteres de chave "{}". Uma entrada de apenas uma palavra, por exemplo, ["ABC"], produz a string de saída da palavra dentro das duas chaves, por exemplo, "{ABC}". Uma entrada de duas palavras, por exemplo, ["ABC", "DEF"], produz a string de saída das duas palavras dentro das duas chaves, com as palavras separadas pela string "e", por exemplo, "{ABC e DEF}". Uma entrada de três ou mais palavras, por exemplo, ["ABC", "DEF", "G", "H"], produz a string de saída de todas menos a última palavra separada por "," com a última palavra separada por "e "e tudo dentro de chaves; por exemplo, "{ABC, DEF, G e H}".

Teste sua função com as seguintes séries de entradas mostrando sua saída aqui nesta página:

[] # (Sem palavras de entrada). ["ABC"] ["ABC", "DEF"] ["ABC", "DEF", "G", "H"]

Nota: Suponha que as palavras sejam sequências não vazias de caracteres maiúsculos para esta tarefa.

## Instructions
## Tests
```yml tests: - text: quibble é uma função. testString: 'assert(typeof quibble === "function", "quibble is a function.");' - text: 'quibble(["ABC"]) deve retornar uma string.' testString: 'assert(typeof quibble(["ABC"]) === "string", "quibble(["ABC"]) should return a string.");' - text: 'quibble([]) deve retornar "{}".' testString: 'assert.equal(quibble(testCases[0]), results[0], "quibble([]) should return "{}".");' - text: 'quibble(["ABC"]) deve retornar "{ABC}".' testString: 'assert.equal(quibble(testCases[1]), results[1], "quibble(["ABC"]) should return "{ABC}".");' - text: 'quibble(["ABC", "DEF"]) deve retornar "{ABC e DEF}".' testString: 'assert.equal(quibble(testCases[2]), results[2], "quibble(["ABC", "DEF"]) should return "{ABC and DEF}".");' - text: 'quibble(["ABC", "DEF", "G", "H"]) deve retornar "{ABC, DEF, G e H}".' testString: 'assert.equal(quibble(testCases[3]), results[3], "quibble(["ABC", "DEF", "G", "H"]) should return "{ABC,DEF,G and H}".");' ```
## Challenge Seed
```js function quibble (words) { // Good luck! return true; } ```
### After Test
```js console.info('after the test'); ```
## Solution
```js // solution required ```