20
submitted 1 year ago* (last edited 1 year ago) by Agility0971@lemmy.world to c/linux@lemmy.ml

Can someone explain why this would make the command wait forever? What is tee waiting for?

echo "test" | sudo tee newfile

What would be a scriptable workaround for such cases?

Edit: this command would not terminate in zsh. This works fine in bash tho.

all 17 comments
sorted by: hot top new old
[-] bleistift2@sopuli.xyz 8 points 1 year ago

Can’t reproduce.

16:22:48:~/tmp$ echo foo | sudo tee newfile
[sudo] Passwort für bleistift2:         
foo

16:23:02:~/tmp$ ls -l newfile
-rw-r--r-- 1 root root 4 Feb 23 16:22 newfile
[-] Agility0971@lemmy.world 3 points 1 year ago

I just switched over to bash and it worked lol. It just didn't return for me in zsh...

[-] 2xsaiko@discuss.tchncs.de 6 points 1 year ago

I use zsh and it works fine for me fwiw. Same with zsh --no-rcs (which doesn't load zshrc). Maybe you have some weird setting enabled?

[-] bleistift2@sopuli.xyz 3 points 1 year ago

My initial guess was that sudo would eat up the echo’d foo as the password. Maybe sudo works differently when invoked via zsh?

[-] Agility0971@lemmy.world 1 points 1 year ago

sudo does not prompt for password in my container. It just elevates the privileges straight away. Yeah, it's hard to tell. Or test for that matter.

[-] MyNameIsRichard@lemmy.ml 1 points 1 year ago* (last edited 1 year ago)

It works here in zsh, did you mistype the closing quote? Although that alters my prompt.

[-] Agility0971@lemmy.world 1 points 1 year ago* (last edited 1 year ago)

no way. I'm in /tmp for this one

echo 'test' | tee newfile
tee: newfile: Permission denied
test
echo 'test' | sudo tee newfile #the prompt never returns when running this in zsh
[-] hallettj@leminal.space 5 points 1 year ago

I'm gonna take a couple of stabs in the dark.

According to this Stack Overflow answer using tee can prevent the prompt from drawing which makes it appear that a script has not terminated. The answerer's workaround is to put a very short sleep command after the tee command.

If this is what happened to you maybe the reason the script works in bash but not in zsh is because you have different prompts configured in those two shells.

Another idea is to replace tee with sponge from moreutils. The difference is that sponge waits for the end of stdin before it starts writing which can avoid problems in some situations.

[-] Agility0971@lemmy.world 5 points 1 year ago

Nice one, didn't know about moreutils. I indeed used p10k on top of zsh. New zsh instance without sourcing anything zsh --no-rcs managed to write to file without issues. Thanks

[-] beeng@discuss.tchncs.de 3 points 1 year ago

Why does newfile need sudo to be created?

You need it to be owned by root?

[-] Agility0971@lemmy.world 1 points 1 year ago

yeah indeed. I'm setting up a container with these instructions for ROS2. There you'll have to add a repository to the apt sources list.

[-] enumerator4829@sh.itjust.works 2 points 1 year ago

ROS

Fly you fools!

[-] just_another_person@lemmy.world 1 points 1 year ago* (last edited 1 year ago)

Are you saying it waits forever, or you read somewhere it will wait forever and you want clarification?

Guessing that file doesn't exist already is the problem, and you don't even need to use tee in this example.

[-] Agility0971@lemmy.world 1 points 1 year ago

what I was saying was that echo "text" | sudo tee newfile would hang and never return and needs to be interrupted. I just noticed this does not happen in bash but I was testing in zsh.

Guessing that file doesn't exist already is the problem, and you don't even need to use tee in this example.

you've missed the point here I'm afraid. But I'll blame it on my for not explaining properly what I was intending to do.

[-] just_another_person@lemmy.world 2 points 1 year ago* (last edited 1 year ago)

ZSH is bash-compliant, but will not always behave like bash in all situations.

Add sh -c before echo and see if that works

[-] Agility0971@lemmy.world 3 points 1 year ago

yep. that did it. I had to wrap the entire thing in quotes though

sh -c "echo 'test' | sudo tee newfile"
this post was submitted on 23 Feb 2025
20 points (91.7% liked)

Linux

63052 readers
334 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 6 years ago
MODERATORS