zsh-workers
 help / color / mirror / code / Atom feed
* Re: PATCH: prompt escape tests
@ 2000-02-02  8:34 Sven Wischnowsky
  2000-02-02 16:21 ` Tanaka Akira
  0 siblings, 1 reply; 5+ messages in thread
From: Sven Wischnowsky @ 2000-02-02  8:34 UTC (permalink / raw)
  To: zsh-workers


Peter Stephenson wrote:

> If I remember, there was a failed test reported by Sven to do with
> different system behaviour which hasn't been fixed up yet.

I wanted to mention that again anyway... A collegue noticed this for
some newer Solaris version, too: nowadays some systems don't update
the atime inode field anymore when a file is read, which makes the -N
condition test fail.

Bye
 Sven


--
Sven Wischnowsky                         wischnow@informatik.hu-berlin.de


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: PATCH: prompt escape tests
  2000-02-02  8:34 PATCH: prompt escape tests Sven Wischnowsky
@ 2000-02-02 16:21 ` Tanaka Akira
  2000-02-02 16:51   ` Dan Nelson
  0 siblings, 1 reply; 5+ messages in thread
From: Tanaka Akira @ 2000-02-02 16:21 UTC (permalink / raw)
  To: zsh-workers

In article <200002020834.JAA09905@beta.informatik.hu-berlin.de>,
  Sven Wischnowsky <wischnow@informatik.hu-berlin.de> writes:

> I wanted to mention that again anyway... A collegue noticed this for
> some newer Solaris version, too: nowadays some systems don't update
> the atime inode field anymore when a file is read, which makes the -N
> condition test fail.

Z:akr@thorax% uname
Linux
Z:akr@thorax% df .
Filesystem           1k-blocks      Used Available Use% Mounted on
crane:/ldl3            3939604   1660770   2274895  42% /amd/crane/root/ldl3
Z:akr@thorax% make check
...
Test ./07cond.ztst failed: bad status 1, expected 0 from:
  cat unmodified
  touch newnewnew
  [[ -N newnewnew && ! -N unmodified ]]
Was testing: -N cond
./07cond.ztst: test failed.
...

This problem is not Solaris specific and can be reproduced on Linux.
I think it is caused by NFS.
-- 
Tanaka Akira


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: PATCH: prompt escape tests
  2000-02-02 16:21 ` Tanaka Akira
@ 2000-02-02 16:51   ` Dan Nelson
  2000-02-02 17:33     ` atime (Re: PATCH: prompt escape tests) Tanaka Akira
  0 siblings, 1 reply; 5+ messages in thread
From: Dan Nelson @ 2000-02-02 16:51 UTC (permalink / raw)
  To: Tanaka Akira; +Cc: zsh-workers

In the last episode (Feb 03), Tanaka Akira said:
> In article <200002020834.JAA09905@beta.informatik.hu-berlin.de>,
>   Sven Wischnowsky <wischnow@informatik.hu-berlin.de> writes:
> 
> > I wanted to mention that again anyway... A collegue noticed this
> > for some newer Solaris version, too: nowadays some systems don't
> > update the atime inode field anymore when a file is read, which
> > makes the -N condition test fail.
>
> This problem is not Solaris specific and can be reproduced on Linux.
> I think it is caused by NFS.

I think it's a POSIX requirement that atime must be updated.
 
Lots of unixes do let let you disable atime updates though (usually by
mount -o noatime).  It's useful for news servers or FTP archives that
do a lot of reading and don't really care about the atime field.  I
looked on my Solaris 2.6 box and there doesn't seem to be a way to
disable atime updates.  7 or 8 might very well be able to, though.

-- 
	Dan Nelson
	dnelson@emsphone.com


^ permalink raw reply	[flat|nested] 5+ messages in thread

* atime (Re: PATCH: prompt escape tests)
  2000-02-02 16:51   ` Dan Nelson
@ 2000-02-02 17:33     ` Tanaka Akira
  0 siblings, 0 replies; 5+ messages in thread
From: Tanaka Akira @ 2000-02-02 17:33 UTC (permalink / raw)
  To: zsh-workers

In article <20000202105104.D31919@dan.emsphone.com>,
  Dan Nelson <dnelson@emsphone.com> writes:

> I think it's a POSIX requirement that atime must be updated.

Hm.

> Lots of unixes do let let you disable atime updates though (usually by
> mount -o noatime).  It's useful for news servers or FTP archives that
> do a lot of reading and don't really care about the atime field.  I
> looked on my Solaris 2.6 box and there doesn't seem to be a way to
> disable atime updates.  7 or 8 might very well be able to, though.

It's server side config and not related to this problem.

Linux produces NFS requests by `touch t':

02:26:54.406581 thorax.jaist.ac.jp.1258203975 > crane.nfs: 112 lookup fh 32,10/568960 "t" (ttl 62, id 8982)
02:26:54.408238 thorax.jaist.ac.jp.1258203976 > crane.nfs: 144 create fh 32,10/568960 "t" (ttl 62, id 8983)
02:26:54.437421 thorax.jaist.ac.jp.1258203977 > crane.nfs: 136 setattr fh 32,10/569010 (ttl 62, id 8986)

and by `cat t':

02:27:08.065326 thorax.jaist.ac.jp.1258203978 > crane.nfs: 112 lookup fh 32,10/568960 "t" (ttl 62, id 9002)
02:27:08.067635 thorax.jaist.ac.jp.1258203979 > crane.nfs: 104 getattr fh 32,10/569010 (ttl 62, id 9003)

Some requests (especialy requests by `cat t') are omitted by cache.
Anyway, the server cannot updates atime since the client doesn't send
read requests.
-- 
Tanaka Akira


^ permalink raw reply	[flat|nested] 5+ messages in thread

* PATCH: prompt escape tests
@ 2000-02-01 20:54 Peter Stephenson
  0 siblings, 0 replies; 5+ messages in thread
From: Peter Stephenson @ 2000-02-01 20:54 UTC (permalink / raw)
  To: Zsh hackers list

I've been slow producing more tests.  This is for prompt escapes; there's a
bit in the .distfiles hunk to add Bart's funcdef test to the distribution.

As always, this is not supposed to be exhaustive:  if a particular problem
turns up, it's likely to be in something more complicated than what's been
tested, and will have to be added by hand.

If I remember, there was a failed test reported by Sven to do with
different system behaviour which hasn't been fixed up yet.

One thing that turned up here is that `prompt -P %~' doesn't work in
non-interactive shells, i.e. doesn't do the directory table lookup (or
doesn't even put it into a directory table, I haven't checked).
Whether this is intentional or not, it's not mentioned in the manual.  I
can't see any good reason for it.

Index: Test/.distfiles
===================================================================
RCS file: /home/pws/CVSROOT/projects/zsh/Test/.distfiles,v
retrieving revision 1.4
diff -u -r1.4 .distfiles
--- Test/.distfiles	2000/01/14 12:33:36	1.4
+++ Test/.distfiles	2000/02/01 20:43:58
@@ -2,5 +2,6 @@
     .cvsignore .distfiles Makefile.in
     ztst.zsh
     01grammar.ztst 02alias.ztst 03quoting.ztst 04redirect.ztst
-    05command.ztst 06arith.ztst 07cond.ztst 08traps.ztst 50cd.ztst
+    05command.ztst 06arith.ztst 07cond.ztst 08traps.ztst 09funcdef.ztst
+    10prompt.ztst 50cd.ztst
 '
Index: Test/10prompt.ztst
===================================================================
RCS file: 10prompt.ztst
diff -N 10prompt.ztst
--- /dev/null	Tue May  5 21:32:27 1998
+++ 10prompt.ztst	Tue Feb  1 20:43:33 2000
@@ -0,0 +1,106 @@
+%prep
+
+  mydir=$PWD
+  SHLVL=2
+  setopt extendedglob
+
+%test
+
+# 'mydir=$PWD; hash -d mydir; print -P %~' doesn't seem to abbreviate
+# to ~mydir in a non-interactive shell.  Is this correct?
+
+  print -P '  %%%):  %)
+  %%d:  %d
+  %%1/: %1/
+  %%h:  %h
+  %%L:  %L
+  %%M:  %M
+  %%m:  %m
+  %%n:  %n
+  %%N:  %N
+  %%i:  %i
+  a%%{...%%}b:  a%{%}b
+  '
+0q:Basic prompt escapes as shown.
+>  %):  )
+>  %d:  $mydir
+>  %1/: ${mydir:t}
+>  %h:  0
+>  %L:  2
+>  %M:  $HOST
+>  %m:  ${HOST%%.*}
+>  %n:  $USERNAME
+>  %N:  ZTST_execchunk
+>  %i:  2
+>  a%{...%}b:  ab
+>  
+
+  true
+  print -P '%?'
+  false
+  print -P '%?'
+0:`%?' prompt escape
+>0
+>1
+
+  PS4="%_> "
+  setopt xtrace
+  if true; then true; else false; fi
+  unsetopt xtrace
+0:`%_' prompt escape
+?if> true
+?then> true
+?> unsetopt xtrace
+
+  diff =(print -P '%#') =(print -P '%(!.#.%%)')
+0:`%#' prompt escape and its equivalent
+
+  psvar=(caesar adsum jam forte)
+  print -P '%v' '%4v'
+0:`%v' prompt escape
+>caesar forte
+
+  true
+  print -P '%(?.true.false)'
+  false
+  print -P '%(?.true.false)'
+0:ternary prompt escapes
+>true
+>false
+
+  print -P '%10<...<truncated at 10%<< Not truncated'
+  print -P '%10>...>truncated at 10%>> Not truncated'
+0:prompt truncation
+>...d at 10 Not truncated
+>truncat... Not truncated
+
+# It's hard to check the time and date as they are moving targets.
+# We therefore just check that various forms of the date are consistent.
+# In fact, if you perform this at midnight it can still fail.
+# We could test for that, but we can't be bothered.
+# I hope LC_ALL is enough to make the format what's expected.
+
+  LC_ALL=C
+  date1=$(print -P %w)
+  date2=$(print -P %W)
+  date3=$(print -P %D)
+  if [[ $date1 != [A-Z][a-z][a-z][[:blank:]]##[0-9]## ]]; then
+    print "Date \`$date1' is not in the form \`Day DD' (e.g. \`Mon 1'"
+  fi
+  if [[ $date2 != [0-9][0-9]/[0-9][0-9]/[0-9][0-9] ]]; then
+    print "Date \`$date2' is not in the form \`DD/MM/YYYY'"
+  fi
+  if [[ $date3 != [0-9][0-9]-[0-9][0-9]-[0-9][0-9] ]]; then
+    print "Date \`$date3' is not in the form \`YY-MM-DD'"
+  fi
+  if (( $date1[5,-1] != $date2[4,5] )) || (( $date2[4,5] != $date3[8,9] ))
+  then
+    print "Days of month do not agree in $date1, $date2, $date3"
+  fi
+  if (( $date2[1,2] != $date3[4,5] )); then
+    print "Months do not agree in $date2, $date3"
+  fi
+  if (( $date2[7,8] != $date3[1,2] )); then
+    print "Years do not agree in $date2, $date3"
+  fi
+0:Dates produced by prompt escapes

-- 
Peter Stephenson <pws@pwstephenson.fsnet.co.uk>


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2000-02-02 17:33 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2000-02-02  8:34 PATCH: prompt escape tests Sven Wischnowsky
2000-02-02 16:21 ` Tanaka Akira
2000-02-02 16:51   ` Dan Nelson
2000-02-02 17:33     ` atime (Re: PATCH: prompt escape tests) Tanaka Akira
  -- strict thread matches above, loose matches on Subject: below --
2000-02-01 20:54 PATCH: prompt escape tests Peter Stephenson

Code repositories for project(s) associated with this public inbox

	https://git.vuxu.org/mirror/zsh/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).