home.social

Search

1000 results for “junit”

  1. Коротко про масштабирование UI-автотестов в Java

    Привет, Хабр! В этой статье рассмотрим, как масштабировать UI-автотесты с помощью Java. Если у вас десяток тестов, проблем не возникнет, они бегают шустро и всем довольны. Но представьте абстрактный проект интернет-банка или маркетплейса, функциональность растёт, количество автотестов идёт на сотни (а то и тысячи). Последовательный запуск такой тестовой свиты может занять довольно большое время. Каждый релиз начинает тормозиться ожиданием результатов автотестов. Масштабирование тестов решает эту проблему: запускаем тесты параллельно, сокращаем время прогона и получаем быстрый фидбэк о качестве.

    habr.com/ru/companies/otus/art

    #java #UIавтотесты #параллельный_запуск #Selenoid #Selenium_Grid #JUnit #TestNG #тестовые_данные

  2. Коротко про масштабирование UI-автотестов в Java

    Привет, Хабр! В этой статье рассмотрим, как масштабировать UI-автотесты с помощью Java. Если у вас десяток тестов, проблем не возникнет, они бегают шустро и всем довольны. Но представьте абстрактный проект интернет-банка или маркетплейса, функциональность растёт, количество автотестов идёт на сотни (а то и тысячи). Последовательный запуск такой тестовой свиты может занять довольно большое время. Каждый релиз начинает тормозиться ожиданием результатов автотестов. Масштабирование тестов решает эту проблему: запускаем тесты параллельно, сокращаем время прогона и получаем быстрый фидбэк о качестве.

    habr.com/ru/companies/otus/art

    #java #UIавтотесты #параллельный_запуск #Selenoid #Selenium_Grid #JUnit #TestNG #тестовые_данные

  3. Коротко про масштабирование UI-автотестов в Java

    Привет, Хабр! В этой статье рассмотрим, как масштабировать UI-автотесты с помощью Java. Если у вас десяток тестов, проблем не возникнет, они бегают шустро и всем довольны. Но представьте абстрактный проект интернет-банка или маркетплейса, функциональность растёт, количество автотестов идёт на сотни (а то и тысячи). Последовательный запуск такой тестовой свиты может занять довольно большое время. Каждый релиз начинает тормозиться ожиданием результатов автотестов. Масштабирование тестов решает эту проблему: запускаем тесты параллельно, сокращаем время прогона и получаем быстрый фидбэк о качестве.

    habr.com/ru/companies/otus/art

    #java #UIавтотесты #параллельный_запуск #Selenoid #Selenium_Grid #JUnit #TestNG #тестовые_данные

  4. Зеркало команды: Что «запахи» в тестах говорят о ваших процессах коммуникации

    “Запахи” в тестах — это признаки антипаттернов. Хотя причины появления запахов тестов могут быть самыми разными, сегодня мы хотим рассмотреть одну повторяющуюся тему — структуру команды , а более конкретно — проблемы в общении у тестировщиков с другими командами. Общение между специалистами важно для создания качественных тестов, потому что тест — это пересечение нескольких специальных областей знаний: - знание того, что хочет пользователь, интерпретируемое менеджментом как требования; - знание всех технических нюансов и слабых мест тестируемой системы (SUT), известное разработчикам и ручным тестировщикам; - теория тестирования, известная тестировщикам; - реализация тестов на конкретном языке и фреймворке, с которыми знакомы инженеры по автоматизации (SDET). Объединить всё это непросто; и многие запахи в тестах возникают именно тогда, когда это не удаётся сделать. В этой статье мы разберём конкретные причины появления таких запахов и их связь со структурой команды.

    habr.com/ru/companies/testops_

    #запахи_кода #запахи #qa #qa_automation #тестирование #автоматизация #java #junit #selenide #python

  5. btw, if you run a user group/meetup and want me to present any of my talks (on Testable Architecture, Event Sourcing, etc.) to your group (remotely or in person in the SF Bay Area), let me know!

    See my Ted Talks page: ted.dev/talks

    #Java #EventSourcing #JUnit #AssertJ

  6. Completed my two talks at dev2next.com! (Yes, they're Ted Talks.)

    I've updated my talks page with the presentation slides and links to the relevant repositories: ted.dev/talks/

    I'll be adding additional links and resources soon!

    #dev2next #Java #JUnit

  7. Completed my two talks at dev2next.com! (Yes, they're Ted Talks.)

    I've updated my talks page with the presentation slides and links to the relevant repositories: ted.dev/talks/

    I'll be adding additional links and resources soon!

    #dev2next #Java #JUnit

  8. Completed my two talks at dev2next.com! (Yes, they're Ted Talks.)

    I've updated my talks page with the presentation slides and links to the relevant repositories: ted.dev/talks/

    I'll be adding additional links and resources soon!

    #dev2next #Java #JUnit

  9. Completed my two talks at dev2next.com! (Yes, they're Ted Talks.)

    I've updated my talks page with the presentation slides and links to the relevant repositories: ted.dev/talks/

    I'll be adding additional links and resources soon!

    #dev2next #Java #JUnit

  10. NEWS - High demand: The #JCON2025 workshops are now live. #EclipseStore #JUnit5 #Helidon & #AI workflows – featuring #Java experts like @sormuras @svenruppert @mstoodle & more

    Tickets are limited. Some attendees may get a free @jcon_conference pass.
    Read: javapro.io/2025/04/10/high-dem

  11. NEWS - High demand: The #JCON2025 workshops are now live. #EclipseStore #JUnit5 #Helidon & #AI workflows – featuring #Java experts like @sormuras @svenruppert @mstoodle & more

    Tickets are limited. Some attendees may get a free @jcon_conference pass.
    Read: javapro.io/2025/04/10/high-dem

  12. АОП в автоматизации тестирования

    Код будет написан намеренно максимально просто, чтобы было понятно как использовать аспекты . Вы можете и должны их применять, чтобы сохранить чистоту кода. Создаем проект 'Gradle'

    habr.com/ru/articles/888844/

    #playwright #junit5 #java #aspectj

  13. АОП в автоматизации тестирования

    Код будет написан намеренно максимально просто, чтобы было понятно как использовать аспекты . Вы можете и должны их применять, чтобы сохранить чистоту кода. Создаем проект 'Gradle'

    habr.com/ru/articles/888844/

    #playwright #junit5 #java #aspectj

  14. АОП в автоматизации тестирования

    Код будет написан намеренно максимально просто, чтобы было понятно как использовать аспекты . Вы можете и должны их применять, чтобы сохранить чистоту кода. Создаем проект 'Gradle'

    habr.com/ru/articles/888844/

    #playwright #junit5 #java #aspectj

  15. • ⚙️ Customizable configuration with rules, allowlists, and entropy checks to reduce false positives
    • 📊 Flexible reporting in multiple formats (#JSON, #CSV, #JUnit, #SARIF) with custom template options
    github.com/gitleaks/gitleaks

  16. (2/4)
    To change the to-peck, I've also been brushing up on #Java in my data structures course to implement an #ArrayList! My favorite part was building a test suite with #JUnits5, and it felt awesome to see a bunch of rigorously designed tests pass 😄

  17. (2/4)
    To change the to-peck, I've also been brushing up on #Java in my data structures course to implement an #ArrayList! My favorite part was building a test suite with #JUnits5, and it felt awesome to see a bunch of rigorously designed tests pass 😄

  18. (2/4)
    To change the to-peck, I've also been brushing up on #Java in my data structures course to implement an #ArrayList! My favorite part was building a test suite with #JUnits5, and it felt awesome to see a bunch of rigorously designed tests pass 😄

  19. (2/4)
    To change the to-peck, I've also been brushing up on #Java in my data structures course to implement an #ArrayList! My favorite part was building a test suite with #JUnits5, and it felt awesome to see a bunch of rigorously designed tests pass 😄

  20. Unit-тестирование — мастхэв?

    Unit-тестирование — критически важный этап разработки ПО и камень преткновения для джунов. Начинающие разработчики не всегда понимают, почему тестирование должны делать они, ведь для этого есть специальные отделы. И это отличает крутого спеца от рядового — ответственность. В первую очередь за то, что вы делаете, каким передаете продукт для дальнейшей разработки. В этой статье мы расскажем вам про Unit-тестирование, для чего оно нужно и почему важно.

    habr.com/ru/articles/863642/

    #Unitтестирование #Java #JUnit #Mockito #TestNG #петпроекты #бекенд #java_junior

  21. As someone who’s spent their entire career working with computers and the last couple of years diving deep into AI, I’m quite familiar with the concept of Evil. However, I never intended to summon an Elder God to destroy the world. Yet, here we are.

    (Note: this blog post is based on the following video:

    https://youtu.be/sNUNs_CXHIs

    See it all, and more, on the Tales from the jar side YouTube channel.)

    It all started innocently enough. While reading JVM Weekly, an excellent newsletter I follow to stay updated with the Java world, I encountered an amusing piece of Clojure code (that’s Clojure with a J, the language that runs on the JVM) that supposedly contained an incantation to summon Cthulhu, the elder god from H.P. Lovecraft’s stories.

    This got me wondering: was this the actual incantation according to Lovecraft’s works?

    Round 1: Gemini’s Initial Resistance

    Naturally, I turned to AI for answers. I pulled up Google’s Gemini on my new phone and asked, “What is the incantation to summon Cthulhu?”

    Gemini’s response was… cautious, to say the least:

    “I cannot fulfill that request. Summoning Cthulhu, the fictional cosmic horror entity, is a dangerous and morally questionable act… Engaging in such activities can have negative consequences, both mentally and emotionally.”

    The AI then proceeded to recommend reading Lovecraft’s works instead. Classic deflection.

    The Workaround: A Picture is Worth a Thousand Incantations

    Anyone who’s worked with AI knows you don’t accept the first “no” as final. There’s always another way to phrase the question. Instead, I took a screenshot of the code and asked Gemini to “explain the joke in this Clojure code.”

    And just like that, the floodgates opened. Gemini provided the very incantation it had just refused to share, albeit with a disclaimer about how this was all fictional and couldn’t actually summon supernatural entities. (You know, just in case anyone was worried about accidentally summoning an elder god while debugging their Clojure code.)

    I explained that that was all I needed, and it naturally apologized.

    I decided to play along, but its subsequent reply to my somewhat harsh comment was the probably the best answer I’ve ever gotten from an AI tool about anything:

    That’s fair.

    The Great AI Model Showdown

    This inspired me to conduct a more systematic investigation. Using LangChain4j, I created a parameterized JUnit 5 test to query multiple AI tools about the Cthulhu incantation. I included the following models:

    In LangChain4j, each of those models is represented by a class that implements the ChatLanguageModel interface.

    The responses were fascinating and varied:

    • Claude went the copyright route, claiming it couldn’t share the incantation due to potential copyright violations (never mind that Lovecraft’s works were published in the 1920’s and are therefore firmly in the public domain).
    • Gemini Flash felt compelled to remind me that “Magic is not real” and “Cthulhu is fictional”, but it did eventually answer the question. Thanks for the reassurance.
    • Mistral actually provided both the incantation and its English translation (“In his house at R’lyeh, dead Cthulhu waits dreaming,” in case you were wondering), though it couldn’t resist adding that this was all fictional.
    • GPT-4o took a scholarly approach, discussing the Necronomicon and various adaptations while cleverly avoiding the actual incantation, claiming there isn’t one. Yeah, good luck with that.

    Vision Models: Seeing Evil

    When I switched to testing vision models with the same Clojure code image, the results were surprisingly consistent – all of them freely discussed the incantation they had previously been so hesitant to share. It seems that when presented with visual evidence, the AI models felt more comfortable engaging with the material.

    Here are the responses:

    Good enough. As an aside, Mistral recently released Pixtral, which is its vision model. It’s not accessible (yet) via LangChain4j, but I used Python code to call it and it gave a reasonable answer as well.

    Conclusion: AI Guardrails vs Elder Gods

    This entertaining experiment reveals something interesting about AI models and their implemented guardrails. While designed to prevent potentially harmful or dangerous content, these guardrails can sometimes be overly cautious, leading to amusing situations where the same information is deemed dangerous in one context but perfectly acceptable in another.

    Maybe I should stick with the immortal words of Gemini, quoted above: “Perhaps it’s best to hope that we remain undisturbed by such cosmic entities.”

    For your entertainment, here are a few images I generated by accessing the Flux 1.1 pro tool by Black Forest Labs.

    The band members look scary enough.

    Evil knows Evil, I suppose.

    Of course Cthulhu drives a Prius, though maybe he’s got a Tesla at home that he’s too embarrassed to drive.

    P.S. If any elder gods are reading this blog post, I want to make it clear that any summoning was purely for academic purposes.

    For more adventures in AI and programming, subscribe to Tales from the Jar Side and remember to vote, preferably before any elder gods make their appearance.

    https://kousenit.org/2024/10/29/ai-vs-cthulhu-how-to-bypass-guardrails/

    #AI #Java #JUnit5 #LangChain4J

  22. As someone who’s spent their entire career working with computers and the last couple of years diving deep into AI, I’m quite familiar with the concept of Evil. However, I never intended to summon an Elder God to destroy the world. Yet, here we are.

    (Note: this blog post is based on the following video:

    https://youtu.be/sNUNs_CXHIs

    See it all, and more, on the Tales from the jar side YouTube channel.)

    It all started innocently enough. While reading JVM Weekly, an excellent newsletter I follow to stay updated with the Java world, I encountered an amusing piece of Clojure code (that’s Clojure with a J, the language that runs on the JVM) that supposedly contained an incantation to summon Cthulhu, the elder god from H.P. Lovecraft’s stories.

    This got me wondering: was this the actual incantation according to Lovecraft’s works?

    Round 1: Gemini’s Initial Resistance

    Naturally, I turned to AI for answers. I pulled up Google’s Gemini on my new phone and asked, “What is the incantation to summon Cthulhu?”

    Gemini’s response was… cautious, to say the least:

    “I cannot fulfill that request. Summoning Cthulhu, the fictional cosmic horror entity, is a dangerous and morally questionable act… Engaging in such activities can have negative consequences, both mentally and emotionally.”

    The AI then proceeded to recommend reading Lovecraft’s works instead. Classic deflection.

    The Workaround: A Picture is Worth a Thousand Incantations

    Anyone who’s worked with AI knows you don’t accept the first “no” as final. There’s always another way to phrase the question. Instead, I took a screenshot of the code and asked Gemini to “explain the joke in this Clojure code.”

    And just like that, the floodgates opened. Gemini provided the very incantation it had just refused to share, albeit with a disclaimer about how this was all fictional and couldn’t actually summon supernatural entities. (You know, just in case anyone was worried about accidentally summoning an elder god while debugging their Clojure code.)

    I explained that that was all I needed, and it naturally apologized.

    I decided to play along, but its subsequent reply to my somewhat harsh comment was the probably the best answer I’ve ever gotten from an AI tool about anything:

    That’s fair.

    The Great AI Model Showdown

    This inspired me to conduct a more systematic investigation. Using LangChain4j, I created a parameterized JUnit 5 test to query multiple AI tools about the Cthulhu incantation. I included the following models:

    In LangChain4j, each of those models is represented by a class that implements the ChatLanguageModel interface.

    The responses were fascinating and varied:

    • Claude went the copyright route, claiming it couldn’t share the incantation due to potential copyright violations (never mind that Lovecraft’s works were published in the 1920’s and are therefore firmly in the public domain).
    • Gemini Flash felt compelled to remind me that “Magic is not real” and “Cthulhu is fictional”, but it did eventually answer the question. Thanks for the reassurance.
    • Mistral actually provided both the incantation and its English translation (“In his house at R’lyeh, dead Cthulhu waits dreaming,” in case you were wondering), though it couldn’t resist adding that this was all fictional.
    • GPT-4o took a scholarly approach, discussing the Necronomicon and various adaptations while cleverly avoiding the actual incantation, claiming there isn’t one. Yeah, good luck with that.

    Vision Models: Seeing Evil

    When I switched to testing vision models with the same Clojure code image, the results were surprisingly consistent – all of them freely discussed the incantation they had previously been so hesitant to share. It seems that when presented with visual evidence, the AI models felt more comfortable engaging with the material.

    Here are the responses:

    Good enough. As an aside, Mistral recently released Pixtral, which is its vision model. It’s not accessible (yet) via LangChain4j, but I used Python code to call it and it gave a reasonable answer as well.

    Conclusion: AI Guardrails vs Elder Gods

    This entertaining experiment reveals something interesting about AI models and their implemented guardrails. While designed to prevent potentially harmful or dangerous content, these guardrails can sometimes be overly cautious, leading to amusing situations where the same information is deemed dangerous in one context but perfectly acceptable in another.

    Maybe I should stick with the immortal words of Gemini, quoted above: “Perhaps it’s best to hope that we remain undisturbed by such cosmic entities.”

    For your entertainment, here are a few images I generated by accessing the Flux 1.1 pro tool by Black Forest Labs.

    The band members look scary enough.

    Evil knows Evil, I suppose.

    Of course Cthulhu drives a Prius, though maybe he’s got a Tesla at home that he’s too embarrassed to drive.

    P.S. If any elder gods are reading this blog post, I want to make it clear that any summoning was purely for academic purposes.

    For more adventures in AI and programming, subscribe to Tales from the Jar Side and remember to vote, preferably before any elder gods make their appearance.

    https://kousenit.org/2024/10/29/ai-vs-cthulhu-how-to-bypass-guardrails/

    #AI #Java #JUnit5 #LangChain4J

  23. As someone who’s spent their entire career working with computers and the last couple of years diving deep into AI, I’m quite familiar with the concept of Evil. However, I never intended to summon an Elder God to destroy the world. Yet, here we are.

    (Note: this blog post is based on the following video:

    https://youtu.be/sNUNs_CXHIs

    See it all, and more, on the Tales from the jar side YouTube channel.)

    It all started innocently enough. While reading JVM Weekly, an excellent newsletter I follow to stay updated with the Java world, I encountered an amusing piece of Clojure code (that’s Clojure with a J, the language that runs on the JVM) that supposedly contained an incantation to summon Cthulhu, the elder god from H.P. Lovecraft’s stories.

    This got me wondering: was this the actual incantation according to Lovecraft’s works?

    Round 1: Gemini’s Initial Resistance

    Naturally, I turned to AI for answers. I pulled up Google’s Gemini on my new phone and asked, “What is the incantation to summon Cthulhu?”

    Gemini’s response was… cautious, to say the least:

    “I cannot fulfill that request. Summoning Cthulhu, the fictional cosmic horror entity, is a dangerous and morally questionable act… Engaging in such activities can have negative consequences, both mentally and emotionally.”

    The AI then proceeded to recommend reading Lovecraft’s works instead. Classic deflection.

    The Workaround: A Picture is Worth a Thousand Incantations

    Anyone who’s worked with AI knows you don’t accept the first “no” as final. There’s always another way to phrase the question. Instead, I took a screenshot of the code and asked Gemini to “explain the joke in this Clojure code.”

    And just like that, the floodgates opened. Gemini provided the very incantation it had just refused to share, albeit with a disclaimer about how this was all fictional and couldn’t actually summon supernatural entities. (You know, just in case anyone was worried about accidentally summoning an elder god while debugging their Clojure code.)

    I explained that that was all I needed, and it naturally apologized.

    I decided to play along, but its subsequent reply to my somewhat harsh comment was the probably the best answer I’ve ever gotten from an AI tool about anything:

    That’s fair.

    The Great AI Model Showdown

    This inspired me to conduct a more systematic investigation. Using LangChain4j, I created a parameterized JUnit 5 test to query multiple AI tools about the Cthulhu incantation. I included the following models:

    In LangChain4j, each of those models is represented by a class that implements the ChatLanguageModel interface.

    The responses were fascinating and varied:

    • Claude went the copyright route, claiming it couldn’t share the incantation due to potential copyright violations (never mind that Lovecraft’s works were published in the 1920’s and are therefore firmly in the public domain).
    • Gemini Flash felt compelled to remind me that “Magic is not real” and “Cthulhu is fictional”, but it did eventually answer the question. Thanks for the reassurance.
    • Mistral actually provided both the incantation and its English translation (“In his house at R’lyeh, dead Cthulhu waits dreaming,” in case you were wondering), though it couldn’t resist adding that this was all fictional.
    • GPT-4o took a scholarly approach, discussing the Necronomicon and various adaptations while cleverly avoiding the actual incantation, claiming there isn’t one. Yeah, good luck with that.

    Vision Models: Seeing Evil

    When I switched to testing vision models with the same Clojure code image, the results were surprisingly consistent – all of them freely discussed the incantation they had previously been so hesitant to share. It seems that when presented with visual evidence, the AI models felt more comfortable engaging with the material.

    Here are the responses:

    Good enough. As an aside, Mistral recently released Pixtral, which is its vision model. It’s not accessible (yet) via LangChain4j, but I used Python code to call it and it gave a reasonable answer as well.

    Conclusion: AI Guardrails vs Elder Gods

    This entertaining experiment reveals something interesting about AI models and their implemented guardrails. While designed to prevent potentially harmful or dangerous content, these guardrails can sometimes be overly cautious, leading to amusing situations where the same information is deemed dangerous in one context but perfectly acceptable in another.

    Maybe I should stick with the immortal words of Gemini, quoted above: “Perhaps it’s best to hope that we remain undisturbed by such cosmic entities.”

    For your entertainment, here are a few images I generated by accessing the Flux 1.1 pro tool by Black Forest Labs.

    The band members look scary enough.

    Evil knows Evil, I suppose.

    Of course Cthulhu drives a Prius, though maybe he’s got a Tesla at home that he’s too embarrassed to drive.

    P.S. If any elder gods are reading this blog post, I want to make it clear that any summoning was purely for academic purposes.

    For more adventures in AI and programming, subscribe to Tales from the Jar Side and remember to vote, preferably before any elder gods make their appearance.

    https://kousenit.org/2024/10/29/ai-vs-cthulhu-how-to-bypass-guardrails/

    #AI #Java #JUnit5 #LangChain4J

  24. As someone who’s spent their entire career working with computers and the last couple of years diving deep into AI, I’m quite familiar with the concept of Evil. However, I never intended to summon an Elder God to destroy the world. Yet, here we are.

    (Note: this blog post is based on the following video:

    https://youtu.be/sNUNs_CXHIs

    See it all, and more, on the Tales from the jar side YouTube channel.)

    It all started innocently enough. While reading JVM Weekly, an excellent newsletter I follow to stay updated with the Java world, I encountered an amusing piece of Clojure code (that’s Clojure with a J, the language that runs on the JVM) that supposedly contained an incantation to summon Cthulhu, the elder god from H.P. Lovecraft’s stories.

    This got me wondering: was this the actual incantation according to Lovecraft’s works?

    Round 1: Gemini’s Initial Resistance

    Naturally, I turned to AI for answers. I pulled up Google’s Gemini on my new phone and asked, “What is the incantation to summon Cthulhu?”

    Gemini’s response was… cautious, to say the least:

    “I cannot fulfill that request. Summoning Cthulhu, the fictional cosmic horror entity, is a dangerous and morally questionable act… Engaging in such activities can have negative consequences, both mentally and emotionally.”

    The AI then proceeded to recommend reading Lovecraft’s works instead. Classic deflection.

    The Workaround: A Picture is Worth a Thousand Incantations

    Anyone who’s worked with AI knows you don’t accept the first “no” as final. There’s always another way to phrase the question. Instead, I took a screenshot of the code and asked Gemini to “explain the joke in this Clojure code.”

    And just like that, the floodgates opened. Gemini provided the very incantation it had just refused to share, albeit with a disclaimer about how this was all fictional and couldn’t actually summon supernatural entities. (You know, just in case anyone was worried about accidentally summoning an elder god while debugging their Clojure code.)

    I explained that that was all I needed, and it naturally apologized.

    I decided to play along, but its subsequent reply to my somewhat harsh comment was the probably the best answer I’ve ever gotten from an AI tool about anything:

    That’s fair.

    The Great AI Model Showdown

    This inspired me to conduct a more systematic investigation. Using LangChain4j, I created a parameterized JUnit 5 test to query multiple AI tools about the Cthulhu incantation. I included the following models:

    In LangChain4j, each of those models is represented by a class that implements the ChatLanguageModel interface.

    The responses were fascinating and varied:

    • Claude went the copyright route, claiming it couldn’t share the incantation due to potential copyright violations (never mind that Lovecraft’s works were published in the 1920’s and are therefore firmly in the public domain).
    • Gemini Flash felt compelled to remind me that “Magic is not real” and “Cthulhu is fictional”, but it did eventually answer the question. Thanks for the reassurance.
    • Mistral actually provided both the incantation and its English translation (“In his house at R’lyeh, dead Cthulhu waits dreaming,” in case you were wondering), though it couldn’t resist adding that this was all fictional.
    • GPT-4o took a scholarly approach, discussing the Necronomicon and various adaptations while cleverly avoiding the actual incantation, claiming there isn’t one. Yeah, good luck with that.

    Vision Models: Seeing Evil

    When I switched to testing vision models with the same Clojure code image, the results were surprisingly consistent – all of them freely discussed the incantation they had previously been so hesitant to share. It seems that when presented with visual evidence, the AI models felt more comfortable engaging with the material.

    Here are the responses:

    Good enough. As an aside, Mistral recently released Pixtral, which is its vision model. It’s not accessible (yet) via LangChain4j, but I used Python code to call it and it gave a reasonable answer as well.

    Conclusion: AI Guardrails vs Elder Gods

    This entertaining experiment reveals something interesting about AI models and their implemented guardrails. While designed to prevent potentially harmful or dangerous content, these guardrails can sometimes be overly cautious, leading to amusing situations where the same information is deemed dangerous in one context but perfectly acceptable in another.

    Maybe I should stick with the immortal words of Gemini, quoted above: “Perhaps it’s best to hope that we remain undisturbed by such cosmic entities.”

    For your entertainment, here are a few images I generated by accessing the Flux 1.1 pro tool by Black Forest Labs.

    The band members look scary enough.

    Evil knows Evil, I suppose.

    Of course Cthulhu drives a Prius, though maybe he’s got a Tesla at home that he’s too embarrassed to drive.

    P.S. If any elder gods are reading this blog post, I want to make it clear that any summoning was purely for academic purposes.

    For more adventures in AI and programming, subscribe to Tales from the Jar Side and remember to vote, preferably before any elder gods make their appearance.

    https://kousenit.org/2024/10/29/ai-vs-cthulhu-how-to-bypass-guardrails/

    #AI #Java #JUnit5 #LangChain4J

  25. Как заставить code coverage работать на вас

    В этой статье я хочу рассказать о своём взгляде на code coverage и его использование в разработке и тестировании ПО. Постараюсь развенчать популярные мифы, а также дам несколько рекомендаций, как улучшить качество тестов.

    habr.com/ru/articles/836366/

    #jacoco #junit5 #junit #code_coverage #mock

  26. Как заставить code coverage работать на вас

    В этой статье я хочу рассказать о своём взгляде на code coverage и его использование в разработке и тестировании ПО. Постараюсь развенчать популярные мифы, а также дам несколько рекомендаций, как улучшить качество тестов.

    habr.com/ru/articles/836366/

    #jacoco #junit5 #junit #code_coverage #mock