Skip to content

Commit

Permalink
simplify tip data structure
Browse files Browse the repository at this point in the history
  • Loading branch information
mnishiguchi committed Jul 18, 2023
1 parent 8d975ea commit 3fa871e
Show file tree
Hide file tree
Showing 3 changed files with 136 additions and 198 deletions.
6 changes: 3 additions & 3 deletions lib/nerves_motd.ex
Original file line number Diff line number Diff line change
Expand Up @@ -87,13 +87,13 @@ defmodule NervesMOTD do
@spec tips([option()]) :: IO.ANSI.ansidata()
defp tips(opts) do
if opts[:show_tip] do
{title, content} = Tips.random()
content = Tips.random() |> String.trim()

"""
==========================================================================
[Tip of the day] #{title}
[Tip of the day]
--------------------------------------------------------------------------
#{String.strip(content)}
#{content}
==========================================================================
"""
else
Expand Down
319 changes: 128 additions & 191 deletions lib/nerves_motd/tips.ex
Original file line number Diff line number Diff line change
Expand Up @@ -2,199 +2,136 @@ defmodule NervesMOTD.Tips do
@moduledoc false

@tips [
{
"Toolshed",
"""
Want more traditional shell tools in your Nerves IEx?
Use Toolshed!
Its included by default and has may familiar functions, such as `cat`,
`ls`, or even `weather` 🌤️
https://hexdocs.pm/toolshed
"""
},
{
"Kernek log message",
"""
Need more than Elixir logs? Run `dmesg` to see log messages from device
drivers and the Linux kernel. Nerves also routes kernel log messages to
the Elixir logger.
"""
},
{
"erlinit",
"""
Erlinit is a small program that starts the Erlang VM on boot. It has many
options - especially for debugging startup issues.
https://hexdocs.pm/nerves/advanced-configuration.html#overriding-erlinit-config-from-mix-config
"""
},
{
"Disable automatic reboot",
"""
Nerves automatically reboots devices when the Erlang VM exits. This can
make some debugging harder, but you can easily disable it to let those
sessions hang for debugging
"""
},
{
"Whats in a firmware?",
"""
Use `mix firmware.unpack` to decompress a local copy of your firmware on
host and inspect the files within before installing on device
"""
},
{
"Elixir Circuits libraries",
"""
See if someone has already implemented support for a sensor or other
hardware device that you have by checking
https://elixir-circuits.github.io/.
"""
},
{
"Read-only filesystems",
"""
Nerves stores all BEAM files, the Erlang runtime and various support
libraries/apps in a compressed and read-only SquashFS filesystem.
Need to write to disk? Use the application partition mounted R/W at
`/data`
"""
},
{
"SASL log messages",
"""
Configuring the Elixir Logger to show SASL reports can help debug
unexpected GenServer restarts.
https://hexdocs.pm/logger/Logger.html#module-erlang-otp-integration
"""
},
{
"Viewing the file system",
"""
Sometimes, you just need to see whats on your Nerves device's disk.
Luckily, there are a few ways to do that. You can even use VSCode!
https://embedded-elixir.com/post/2021-05-08-nerves-file-peeking/#sshfs
"""
},
{
"NervesPack",
"""
Get all of the default packages for starting a new Nerves project by
depending on `:nerves_pack`
https://github.com/nerves-project/nerves_pack
"""
},
{
"Hardware watchdogs",
"""
Nerves enables hardware watchdogs and connects them to Erlang's heart
feature to detect and recover from the Erlang VM hanging.
See https://embedded-elixir.com/post/2018-12-10-heart/ to learn more
about this.
"""
},
{
"Copy and paste",
"""
Make small code changes to your running application by copy/pasting
Elixir source files at the IEx prompt.
"""
},
{
"Read-only filesystems",
"""
Nerves stores all BEAM files, the Erlang runtime and various support
libraries and apps in a compressed and read-only SquashFS filesystem.
The writable application partition is mounted at `/data`
"""
},
{
"Device serial numbers",
"""
Identify your Nerves devices using a unique ID that's already programmed
into the hardware using the boardid command. Details at
https://github.com/nerves-project/boardid/ and the boardid.config file.
"""
},
{
"Need an example?",
"""
Nerves maintains a set of examples for common use-cases with devices.
Things like running a phoenix app, using SQLite, controlling GPIO, using
Zig lang, and more!
https://github.com/nerves-project/nerves_examples
"""
},
{
"Logs",
"""
Use `RingLogger.next` to dump the current log buffer to screen.
Use `log_attach` from `Toolshed` to attach the current session to the
Elixir logger for live logs.
https://hexdocs.pm/toolshed/Toolshed.Log.html#log_attach/1
"""
},
{
"Eye from the Sky",
"""
Get some insights to Nerves internals with this high level overview of
the Nerves architecture and choice to use the BEAM VM
https://youtu.be/VzOaSvTcvU4
"""
},
{
"Revert to the previously loaded firmware",
"""
Run `Nerves.Runtime.revert` to go back to the previously loaded firmware.
"""
},
{
"Compiling systems",
"""
Compiling systems on linux or via `mix nerves.system.shell`?
Don't forgot about `make help` and other tips from the Buildroot manual
(thanks @ericr3r)
https://buildroot.org/downloads/manual/manual.html#make-tips
"""
},
{
"Order matters",
"""
Sometimes when compiling Nerves systems, order matters!
Use `make show-build-order` while in `mix nerves.system.shell` to see the
compilation order and make sure all your 🦆🦆 are in a row (thanks
@ericr3r!)
"""
},
{
"RamoopsLogger",
"""
Use the `RamoopsLogger` backend to store log messages in DRAM that can
survive unexpected reboots.
https://github.com/smartrent/ramoops_logger
"""
}
"""
Want more traditional shell tools in your Nerves IEx?
Use Toolshed!
Its included by default and has may familiar functions, such as `cat`,
`ls`, or even `weather` 🌤️
https://hexdocs.pm/toolshed
""",
"""
Need more than Elixir logs? Run `dmesg` to see log messages from device
drivers and the Linux kernel. Nerves also routes kernel log messages to
the Elixir logger.
""",
"""
Erlinit is a small program that starts the Erlang VM on boot. It has many
options - especially for debugging startup issues.
https://hexdocs.pm/nerves/advanced-configuration.html#overriding-erlinit-config-from-mix-config
""",
"""
Nerves automatically reboots devices when the Erlang VM exits. This can
make some debugging harder, but you can easily disable it to let those
sessions hang for debugging
""",
"""
Use `mix firmware.unpack` to decompress a local copy of your firmware on
host and inspect the files within before installing on device
""",
"""
See if someone has already implemented support for a sensor or other
hardware device that you have by checking
https://elixir-circuits.github.io/.
""",
"""
Nerves stores all BEAM files, the Erlang runtime and various support
libraries/apps in a compressed and read-only SquashFS filesystem.
Need to write to disk? Use the application partition mounted R/W at
`/data`
""",
"""
Configuring the Elixir Logger to show SASL reports can help debug
unexpected GenServer restarts.
https://hexdocs.pm/logger/Logger.html#module-erlang-otp-integration
""",
"""
Sometimes, you just need to see whats on your Nerves device's disk.
Luckily, there are a few ways to do that. You can even use VSCode!
https://embedded-elixir.com/post/2021-05-08-nerves-file-peeking/#sshfs
""",
"""
Get all of the default packages for starting a new Nerves project by
depending on `:nerves_pack`
https://github.com/nerves-project/nerves_pack
""",
"""
Nerves enables hardware watchdogs and connects them to Erlang's heart
feature to detect and recover from the Erlang VM hanging.
See https://embedded-elixir.com/post/2018-12-10-heart/ to learn more
about this.
""",
"""
Make small code changes to your running application by copy/pasting
Elixir source files at the IEx prompt.
""",
"""
Nerves stores all BEAM files, the Erlang runtime and various support
libraries and apps in a compressed and read-only SquashFS filesystem.
The writable application partition is mounted at `/data`
""",
"""
Identify your Nerves devices using a unique ID that's already programmed
into the hardware using the boardid command. Details at
https://github.com/nerves-project/boardid/ and the boardid.config file.
""",
"""
Nerves maintains a set of examples for common use-cases with devices.
Things like running a phoenix app, using SQLite, controlling GPIO, using
Zig lang, and more!
https://github.com/nerves-project/nerves_examples
""",
"""
Use `RingLogger.next` to dump the current log buffer to screen.
Use `log_attach` from `Toolshed` to attach the current session to the
Elixir logger for live logs.
https://hexdocs.pm/toolshed/Toolshed.Log.html#log_attach/1
""",
"""
Get some insights to Nerves internals with this high level overview of
the Nerves architecture and choice to use the BEAM VM
https://youtu.be/VzOaSvTcvU4
""",
"""
Run `Nerves.Runtime.revert` to go back to the previously loaded firmware.
""",
"""
Compiling systems on linux or via `mix nerves.system.shell`?
Don't forgot about `make help` and other tips from the Buildroot manual
(thanks @ericr3r)
https://buildroot.org/downloads/manual/manual.html#make-tips
""",
"""
Sometimes when compiling Nerves systems, order matters!
Use `make show-build-order` while in `mix nerves.system.shell` to see the
compilation order and make sure all your 🦆🦆 are in a row (thanks
@ericr3r!)
""",
"""
Use the `RamoopsLogger` backend to store log messages in DRAM that can
survive unexpected reboots.
https://github.com/smartrent/ramoops_logger
"""
]

@type tip :: {title :: String.t(), content :: String.t()}
@type tip :: String.t()

@doc """
List all Nerves tips
Expand Down
9 changes: 5 additions & 4 deletions test/nerves_motd/tips_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,12 @@ defmodule NervesMOTD.TipsTest do
alias NervesMOTD.Tips
doctest NervesMOTD.Tips

test "all" do
assert [{_title, _content} | _] = Tips.all()
test "all returns a list of strings" do
assert [tip | _] = Tips.all()
assert is_binary(tip)
end

test "random" do
assert {_title, _content} = Tips.random()
test "random returns a string" do
assert Tips.random() |> is_binary()
end
end

0 comments on commit 3fa871e

Please sign in to comment.