Retornar erros de script


Meu script não executa.

Como saber os erros que acontecem no script?

Já tentei fazer um Try e Catch, mas não rolou.

Já tentei usar o console.log e também vi nada.

Como fazer para, basicamente retornar qualquer erro de script na variável de saída dele?

Aqui meu script:


function run(respostasheet) {
var json = JSON.parse(respostasheet);
var valorfiltrado;
var valor;
var i;
try {
for (i = 0; i < json.values.length; i++) {
valor = String(json.values[i][0]);
if (valor.includes("teste")){
valorfiltrado = valor;
} else {
valorfiltrado = "nada encontrado";
}
}
}
catch(err) {
valorfiltrado = err.message;
console.log(err);
}
return valorfiltrado;
}

22 comentários

Olá @Jhoni_Desb, tudo bem?


Poderia analisar seu script com o Debug?

Caso não encontre o erro me avise, vamos resolver este problema juntos.

O Try Catch tem que englobar todo o script pra funcionar. Este foi o erro.

Não testei o debug ainda. Realmente vai ajudar muito.

Obrigado

Testei o Debug e lá não tem nada de debug!

Ele também não aponta erros do fluxo, tipo quando o fluxo é travado por algum problema e o bot para de responder.

Ou seja, não vi utilidade ainda. Várias vezes tive que encontrar o erro na unha.

Ainda continuamos na tentativa e erro

Ele não aponta erros de script. Ainda tenho que fazer um Try Catch pra cuspir os erros no fluxo.

Esse Try Catch devia ser fixo no Script. Isso economizaria muito suporte pra vocês.

@Jhoni_Desb, será que estamos falando do mesmo Debug? 🤔


No artigo abaixo apresento como utilizar o Debug e dou um exemplo onde ele pode ajudar muito a entender os problemas que acontecem com seu fluxo.


https://help.blip.ai/hc/pt-br/articles/360022985511-Como-utilizar-a-ferramenta-de-debug-do-Builder


Especialmente em relação à uma ação de Executar Script ele te dá os detalhes de qual foi o erro que aconteceu.


@rafaelpa esse mesmo.


Ele não debugou um erro ao informar um link de imagem que travou ou fluxo:





Embora o carrossel tenha aceitado a imagem e tenha dado o preview corretamente.


Ele também não me avisou que uma variável não estava definida no script. Foi o Try Catch que me retornou na conversa.


Entre outros problemas que me travaram o fluxo e o debug ficava verdinho feliz da vida sem perceber nada.


Esse tipo de retorno que tu me mostrou eu ainda não vi no debug.

Outro bug aqui com o fluxo travado e que o debug não enxerga…

Neste bloco tem um requisição HTTP pra deletar o usuário…

Eu não faço ideia de como resolver, pois o fluxo travou e o debug não retornou nada.


debug_bugado

@Jhoni_Desb,


você já tentou clicar na linha marcada em vermelho:


[“cancela_user”] Executed Entering Actions


Sempre que você clica em uma linha ela se expande e você consegue ver mais detalhes.


*Obs.: Qual browser vc está utilizando? Os ícones não apareceram corretamente pra vc.

Putz, verdade…

Eu uso VPN para proteção dos dados, então quebra algumas coisas as vezes.

Nesse caso, o fluxo travou e a linha não expande pra mim ver no Debug.


Mais um exemplo que o debug não funciona pra Scripts!!!


Depois de recarregar a página com Ctrl+R achei esse erro bizarro!


Failed: ExecuteScript action in 3 milliseconds

order: 0

type: "ExecuteScript"

parsedSettings: {"function":"run","source":"function run(status, retorno) {\n try {\n var str = retorno.toString()\n var mySubSstrtring = str.substring(str.lastIndexOf("&lt;") + 1, str.lastIndexOf("&gt;"));\n return mySubString;\n }\n catch(err) {\n return err;\n }\n}","inputVariables":["statuspagseguro","pagseguro"],"outputVariable":"codigotransacao"}

timestamp: "2019-03-08T19:26:08.091Z"

elapsedMilliseconds: 3

error: "Newtonsoft.Json.JsonSerializationException: Self referencing loop detected for property 'Engine' with type 'Jint.Engine'. Path 'Engine.GlobalEnvironment.Record'.\n at Newtonsoft.Json.Serialization.JsonSerializerInternalWriter.CheckForCircularReference(JsonWriter writer, Object value, JsonProperty property, JsonContract contract, JsonContainerContract containerContract, JsonProperty containerProperty)\n at Newtonsoft.Json.Serialization.JsonSerializerInternalWriter.CalculatePropertyValues(JsonWriter writer, Object value, JsonContainerContract contract, JsonProperty member, JsonProperty property, JsonContract&amp; memberContract, Object&amp; memberValue)\n at Newtonsoft.Json.Serialization.JsonSerializerInternalWriter.SerializeObject(JsonWriter writer, Object value, JsonObjectContract contract, JsonProperty member, JsonContainerContract collectionContract, JsonProperty containerProperty)\n at Newtonsoft.Json.Serialization.JsonSerializerInternalWriter.SerializeObject(JsonWriter writer, Object value, JsonObjectContract contract, JsonProperty member, JsonContainerContract collectionContract, JsonProperty containerProperty)\n at Newtonsoft.Json.Serialization.JsonSerializerInternalWriter.SerializeObject(JsonWriter writer, Object value, JsonObjectContract contract, JsonProperty member, JsonContainerContract collectionContract, JsonProperty containerProperty)\n at Newtonsoft.Json.Serialization.JsonSerializerInternalWriter.SerializeObject(JsonWriter writer, Object value, JsonObjectContract contract, JsonProperty member, JsonContainerContract collectionContract, JsonProperty containerProperty)\n at Newtonsoft.Json.Serialization.JsonSerializerInternalWriter.Serialize(JsonWriter jsonWriter, Object value, Type objectType)\n at Newtonsoft.Json.JsonSerializer.SerializeInternal(JsonWriter jsonWriter, Object value, Type objectType)\n at Newtonsoft.Json.JsonConvert.SerializeObjectInternal(Object value, Type type, JsonSerializer jsonSerializer)\n at Take.Blip.Builder.Actions.ExecuteScript.ExecuteScriptAction.ExecuteAsync(IContext context, ExecuteScriptSettings settings, CancellationToken cancellationToken)\n at Take.Blip.Builder.FlowManager.ProcessActionsAsync(LazyInput lazyInput, IContext context, Action[] actions, ICollection`1 actionTraces, CancellationToken cancellationToken)"

Problema semelhante… tenho um script que faz o fluxo parar por um erro e não sei onde ocorreu. E o debug só mostra cor vermelha, nada além disso.

Estou com o mesmo problema do @Andre_Antivilo. O fluxo para provavelmente por um erro de script mas não há nada no debug que indique qual foi o problema.


Esse debug é bom, já me ajudou em vários casos, mas atualmente ele parece não cobrir todas as possibilidades de erro.

Só pra complementar o tópico: no meu caso o problema era um parâmetro do script que não era uma string JSON e estava sendo parseado com JSON.parse(), gerando um erro de js que não foi apontado pelo builder.

De novo o Debug não debuga nada e me presenteia com “nada” mais uma vez!


blip_debug

Obrigado pelo feedback @Jhoni_Desb 😉

Coloquei meu código num editor online JavaScript e funcionou!

Tem algo muito estranho acontecendo e estamos totalmente cegos pra depurar.

Eu suspeitei que o problema seja estouro de memória e acho que acertei.

Peguei uma pequena parte do meu JSON de retorno e testei, funcionou!

Com meu JSON inteiro não funciona. Ele tem mais de 6 mil elementos com 2 chaves e valores cada.

@rafaelpa vocês podem dar uma atenção nisso pra mim?

@Jhoni_Desb,


não há nada que possamos fazer nesse cenário.

O ideal é que vc trabalhe com esse JSON gigante em uma API do seu lado. Dessa forma sua API pode retornar ao Builder o dado já processado.


Por uma questão de segurança limitamos o número máximo de statements (operações) que um Script JS do Builder pode executar. O limite atual é de 1000 operações.

Então quer dizer que quem desenvolve no Builder, está limitado em vários fatores?

Pode esclarecer melhor os limites de Script do Builder?


E quem não tem servidor, API, SDK?


Rodei aqui e não deu nenhum erro JavaScript Online Compiler (Editor)

Esse limite de 1.000 operações por segurança é uma informação muito vaga.

Tá estranho isso, pois eu posso fazer uma instrução “insegura” e como vão controlar?

Segurança do que? Ataques, Crash, Bulk, Massive?


Lembre ainda que o Debuger não nos diz nada sobre o erro.

Então até o momento, temos apenas suspeitas.


Mil por script? Mil por bot? Mil por fluxo?

Conforme explicado no comentário anterior 1000 por script.


Comente